*,*:before,*:after{box-sizing:border-box}:root{--void-black: #0D0A14;--ancient-dark: #13101E;--rust-shadow: #1A1020;--patina-dark: #161225;--brass-primary: #c9a227;--brass-light: #d4af37;--brass-glow: #ffd700;--copper-aged: #b87333;--copper-dark: #8b4513;--bronze-patina: #5B3A8C;--neon-cyan: #9B59F0;--neon-cyan-dim: #7B3FBE;--neon-amber: #ff9f1c;--neon-rust: #ff6b35;--hologram-blue: #6E5FD6;--parchment: #d4c5a9;--parchment-dark: #9c8b6e;--stone-grey: #4a4a52;--stone-light: #6a6a72;--text-primary: #e8e4d9;--text-secondary: #9c9a8e;--text-accent: var(--brass-light);--text-glow: var(--neon-cyan);--border-ornate: var(--brass-primary);--border-tech: var(--neon-cyan-dim);--shadow-rust: rgba(139, 69, 19, .3);--shadow-neon: rgba(155, 89, 240, .2);--font-medieval: "Cinzel", serif;--font-tech: "Rajdhani", sans-serif;--font-mono: "Share Tech Mono", monospace;--transition-smooth: .3s cubic-bezier(.4, 0, .2, 1);--transition-glitch: .1s steps(2)}body{margin:0;padding:0;font-family:var(--font-tech);font-weight:400;background:var(--void-black);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");background-blend-mode:overlay;background-size:200px 200px}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.1) 2px,rgba(0,0,0,.1) 4px);pointer-events:none;z-index:9999;opacity:.3}::selection{background:var(--brass-primary);color:var(--void-black)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--ancient-dark);border-left:1px solid var(--copper-dark)}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--brass-primary),var(--copper-aged));border-radius:2px;border:1px solid var(--copper-dark)}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,var(--brass-light),var(--brass-primary))}h1,h2,h3,h4,h5,h6{font-family:var(--font-medieval);font-weight:600;letter-spacing:.05em;margin:0}h1{font-size:2.5rem;background:linear-gradient(135deg,var(--brass-light),var(--neon-cyan),var(--brass-primary));background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 8s ease-in-out infinite;text-shadow:0 0 40px var(--shadow-neon)}@keyframes shimmer{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}h2{font-size:1.5rem;color:var(--brass-light);text-shadow:0 0 10px var(--shadow-rust)}h3{font-size:1.25rem;color:var(--text-primary)}p{color:var(--text-secondary);margin:.5rem 0}a{color:var(--neon-cyan);text-decoration:none;transition:var(--transition-smooth);position:relative}a:hover{color:var(--brass-light);text-shadow:0 0 8px var(--neon-cyan)}button{font-family:var(--font-tech);cursor:pointer;border:none;outline:none;transition:var(--transition-smooth)}button:focus-visible{outline:2px solid var(--neon-cyan);outline-offset:2px}.glow-text{text-shadow:0 0 5px var(--neon-cyan),0 0 10px var(--neon-cyan),0 0 20px var(--neon-cyan-dim)}.brass-text{color:var(--brass-light);text-shadow:0 2px 4px var(--shadow-rust)}@keyframes rotate-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes rotate-reverse{0%{transform:rotate(360deg)}to{transform:rotate(0)}}@keyframes pulse-glow{0%,to{opacity:.5}50%{opacity:1}}@keyframes flicker{0%,to{opacity:1}41%{opacity:1}42%{opacity:.8}43%{opacity:1}45%{opacity:.3}46%{opacity:1}}@keyframes data-stream{0%{background-position:0% 0%}to{background-position:0% 100%}}.app{min-height:100vh;display:flex;flex-direction:column;position:relative}.home-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;position:relative;overflow:hidden;background:radial-gradient(ellipse at 20% 80%,rgba(139,69,19,.15) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(123,63,190,.1) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,#12121a,#0a0a0c)}.home-container:before,.home-container:after{content:"";position:absolute;border-radius:50%;border:3px dashed var(--copper-dark);opacity:.15;pointer-events:none}.home-container:before{width:400px;height:400px;top:-100px;right:-100px;animation:rotate-slow 60s linear infinite}.home-container:after{width:300px;height:300px;bottom:-80px;left:-80px;animation:rotate-reverse 45s linear infinite}.guild-crest{position:relative;margin-bottom:2rem}.guild-crest svg{width:120px;height:120px;filter:drop-shadow(0 0 20px var(--brass-primary))}.home-container h1{font-family:var(--font-medieval);font-size:3.5rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.5rem;position:relative;background:linear-gradient(135deg,var(--brass-light) 0%,var(--neon-cyan) 25%,var(--brass-primary) 50%,var(--neon-cyan) 75%,var(--brass-light) 100%);background-size:400% 400%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 8s ease-in-out infinite}.home-container h1:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:200px;height:2px;background:linear-gradient(90deg,transparent,var(--brass-primary),var(--neon-cyan),var(--brass-primary),transparent)}.home-container .subtitle{font-family:var(--font-tech);font-size:1.1rem;color:var(--text-secondary);letter-spacing:.3em;text-transform:uppercase;margin-bottom:3rem}.home-container p{font-family:var(--font-mono);font-size:.9rem;color:var(--neon-cyan-dim);margin-bottom:2rem;opacity:.8}.login-btn{position:relative;display:flex;align-items:center;gap:12px;padding:16px 32px;font-family:var(--font-tech);font-size:1rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-primary);background:linear-gradient(135deg,#5865f233,#5865f21a);border:2px solid var(--copper-aged);border-radius:4px;overflow:hidden;transition:all .3s ease;clip-path:polygon(0 8px,8px 0,calc(100% - 8px) 0,100% 8px,100% calc(100% - 8px),calc(100% - 8px) 100%,8px 100%,0 calc(100% - 8px))}.login-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(155,89,240,.2),transparent);transition:left .5s ease}.login-btn:hover:before{left:100%}.login-btn:hover{border-color:var(--neon-cyan);background:linear-gradient(135deg,#5865f24d,#7b3fbe33);box-shadow:0 0 20px #5865f24d,0 0 40px #9b59f033,inset 0 0 20px #9b59f01a;transform:translateY(-2px)}.login-btn:active{transform:translateY(0)}.login-btn svg{width:24px;height:24px;fill:currentColor}.corner-decor{position:absolute;width:60px;height:60px;border:2px solid var(--copper-dark);opacity:.3}.corner-decor.top-left{top:40px;left:40px;border-right:none;border-bottom:none}.corner-decor.top-right{top:40px;right:40px;border-left:none;border-bottom:none}.corner-decor.bottom-left{bottom:40px;left:40px;border-right:none;border-top:none}.corner-decor.bottom-right{bottom:40px;right:40px;border-left:none;border-top:none}.loading{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;gap:1.5rem;background:var(--void-black)}.loading-spinner{width:60px;height:60px;position:relative}.loading-spinner:before,.loading-spinner:after{content:"";position:absolute;border-radius:50%}.loading-spinner:before{width:100%;height:100%;border:3px solid var(--copper-dark);border-top-color:var(--brass-light);animation:rotate-slow 1s linear infinite}.loading-spinner:after{width:70%;height:70%;top:15%;left:15%;border:2px solid var(--copper-dark);border-bottom-color:var(--neon-cyan);animation:rotate-reverse .8s linear infinite}.loading-text{font-family:var(--font-mono);font-size:.9rem;color:var(--neon-cyan-dim);letter-spacing:.2em;animation:flicker 3s infinite}.dashboard-container{display:flex;min-height:100vh;background:var(--void-black)}.sidebar{width:280px;min-height:100vh;display:flex;flex-direction:column;position:relative;background:linear-gradient(180deg,#12121afa,#0a0a0cfa),url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23b87333' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");border-right:1px solid var(--copper-dark);box-shadow:4px 0 20px #00000080}.sidebar:after{content:"";position:absolute;top:0;right:0;width:1px;height:100%;background:linear-gradient(180deg,transparent,var(--neon-cyan-dim),var(--brass-primary),var(--neon-cyan-dim),transparent);opacity:.5}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--copper-dark);position:relative}.sidebar-header:after{content:"";position:absolute;bottom:0;left:1.5rem;right:1.5rem;height:1px;background:linear-gradient(90deg,transparent,var(--brass-primary),transparent)}.sidebar h2{font-family:var(--font-medieval);font-size:1.3rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;margin:0;background:linear-gradient(135deg,var(--brass-light),var(--neon-cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-subtitle{font-family:var(--font-mono);font-size:.7rem;color:var(--text-secondary);letter-spacing:.2em;text-transform:uppercase;margin-top:.25rem}.version-badge{display:inline-block;font-family:var(--font-mono);font-size:.65rem;color:var(--neon-cyan);background:#9b59f01a;border:1px solid var(--neon-cyan-dim);padding:.2rem .5rem;border-radius:3px;margin-top:.5rem;letter-spacing:.05em;text-transform:uppercase;box-shadow:0 0 10px #9b59f033}.sidebar nav{flex:1;padding:1rem 0}.sidebar nav ul{list-style:none;padding:0;margin:0}.nav-section-title{font-family:var(--font-mono);font-size:.65rem;color:var(--text-secondary);letter-spacing:.2em;text-transform:uppercase;padding:1rem 1.5rem .5rem;opacity:.6}.sidebar nav li{position:relative;margin:2px 8px}.sidebar nav li a,.sidebar nav li span{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:4px;font-family:var(--font-tech);font-size:.95rem;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:all .2s ease;cursor:pointer;border:1px solid transparent}.sidebar nav li a:hover,.sidebar nav li span:hover{color:var(--text-primary);background:#c9a2271a;border-color:#c9a22733}.sidebar nav li.active a,.sidebar nav li.active span{color:var(--brass-light);background:linear-gradient(90deg,rgba(201,162,39,.15),transparent);border-color:var(--brass-primary);border-left-width:3px}.sidebar nav li.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--neon-cyan);box-shadow:0 0 10px var(--neon-cyan);border-radius:0 2px 2px 0}.nav-icon{width:20px;height:20px;opacity:.7;flex-shrink:0}.sidebar nav li.active .nav-icon,.sidebar nav li:hover .nav-icon{opacity:1}.sidebar nav li.disabled span{opacity:.4;cursor:not-allowed}.sidebar nav li.disabled span:hover{background:transparent;border-color:transparent;color:var(--text-secondary)}.coming-soon-badge{font-size:.6rem;padding:2px 6px;background:#7b3fbe33;color:var(--neon-cyan-dim);border-radius:2px;margin-left:auto;font-family:var(--font-mono);letter-spacing:.05em}.user-profile{padding:1rem 1.5rem;margin-top:auto;border-top:1px solid var(--copper-dark);display:flex;align-items:center;gap:12px;position:relative;background:linear-gradient(180deg,transparent,rgba(10,10,12,.5))}.user-profile:before{content:"";position:absolute;top:0;left:1.5rem;right:1.5rem;height:1px;background:linear-gradient(90deg,transparent,var(--brass-primary),transparent)}.avatar-container{position:relative}.avatar{width:42px;height:42px;border-radius:50%;border:2px solid var(--copper-aged);transition:all .3s ease}.avatar:hover{border-color:var(--neon-cyan);box-shadow:0 0 15px #9b59f066}.avatar-container:after{content:"";position:absolute;bottom:2px;right:2px;width:10px;height:10px;background:var(--neon-cyan);border:2px solid var(--ancient-dark);border-radius:50%;box-shadow:0 0 8px var(--neon-cyan)}.user-info{flex:1;min-width:0}.user-name{font-family:var(--font-tech);font-weight:600;font-size:.95rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-family:var(--font-mono);font-size:.7rem;color:var(--brass-primary);letter-spacing:.1em}.logout-btn{padding:8px;background:transparent;border:1px solid var(--copper-dark);border-radius:4px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.logout-btn:hover{border-color:var(--neon-rust);color:var(--neon-rust);background:#ff6b351a}.logout-btn svg{width:18px;height:18px}.content{flex:1;display:flex;flex-direction:column;min-height:100vh;background:radial-gradient(ellipse at 0% 0%,rgba(123,63,190,.03) 0%,transparent 50%),radial-gradient(ellipse at 100% 100%,rgba(201,162,39,.03) 0%,transparent 50%),var(--void-black)}.content-header{padding:1.5rem 2rem;border-bottom:1px solid var(--copper-dark);display:flex;align-items:center;justify-content:space-between;background:#12121a80;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:sticky;top:0;z-index:100}.content-header:after{content:"";position:absolute;bottom:0;left:2rem;right:2rem;height:1px;background:linear-gradient(90deg,var(--brass-primary),var(--neon-cyan),var(--brass-primary));opacity:.3}.content-header h1{font-family:var(--font-medieval);font-size:1.75rem;background:linear-gradient(135deg,var(--text-primary),var(--brass-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-actions{display:flex;gap:12px}.dashboard-content{flex:1;padding:2rem;overflow-y:auto}.card{position:relative;background:linear-gradient(135deg,#12121ae6,#1a1518e6);border:1px solid var(--copper-dark);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;overflow:hidden;transition:all .3s ease}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--brass-primary),var(--neon-cyan),var(--brass-primary));opacity:.6}.card:hover{border-color:var(--brass-primary);box-shadow:0 4px 20px #0006,0 0 30px #c9a2271a;transform:translateY(-2px)}.card h3{font-family:var(--font-medieval);font-size:1.2rem;color:var(--brass-light);margin-bottom:.75rem}.card p{font-family:var(--font-tech);color:var(--text-secondary);line-height:1.6}.card.card-glow{border-color:var(--neon-cyan-dim)}.card.card-glow:before{background:linear-gradient(90deg,var(--neon-cyan),var(--brass-primary),var(--neon-cyan));opacity:.8}.card.card-glow:hover{box-shadow:0 4px 20px #0006,0 0 40px #9b59f026}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{position:relative;background:linear-gradient(135deg,#12121af2,#151a18f2);border:1px solid var(--copper-dark);border-radius:8px;padding:1.25rem;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,var(--brass-primary),var(--neon-cyan))}.stat-card:hover{border-color:var(--brass-primary);transform:translateY(-2px);box-shadow:0 4px 15px #0000004d}.stat-icon{width:40px;height:40px;margin-bottom:.75rem;color:var(--neon-cyan);opacity:.8}.stat-value{font-family:var(--font-medieval);font-size:2rem;font-weight:700;color:var(--brass-light);line-height:1}.stat-label{font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary);letter-spacing:.1em;text-transform:uppercase;margin-top:.25rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;font-family:var(--font-tech);font-size:.9rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;border-radius:4px;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.btn-primary{background:linear-gradient(135deg,var(--brass-primary),var(--copper-aged));color:var(--void-black);border:1px solid var(--brass-light)}.btn-primary:hover{background:linear-gradient(135deg,var(--brass-light),var(--brass-primary));box-shadow:0 0 20px #c9a22766;transform:translateY(-1px)}.btn-secondary{background:transparent;color:var(--text-primary);border:1px solid var(--copper-dark)}.btn-secondary:hover{border-color:var(--neon-cyan);color:var(--neon-cyan);box-shadow:0 0 15px #9b59f033}.btn-danger{background:transparent;color:var(--neon-rust);border:1px solid var(--neon-rust)}.btn-danger:hover{background:#ff6b351a;box-shadow:0 0 15px #ff6b354d}.welcome-section{margin-bottom:2rem}.welcome-card{position:relative;background:linear-gradient(135deg,#12121af2,#1a1518e6),url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23b87333' fill-opacity='0.02'%3E%3Ccircle cx='50' cy='50' r='40' stroke='%23b87333' stroke-width='1' fill='none'/%3E%3Ccircle cx='50' cy='50' r='30' stroke='%23b87333' stroke-width='1' fill='none'/%3E%3Ccircle cx='50' cy='50' r='20' stroke='%23b87333' stroke-width='1' fill='none'/%3E%3C/g%3E%3C/svg%3E");border:1px solid var(--copper-dark);border-radius:12px;padding:2rem;overflow:hidden}.welcome-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--brass-primary),var(--neon-cyan),var(--brass-primary),var(--neon-cyan),var(--brass-primary));background-size:200% 100%;animation:shimmer 4s linear infinite}.welcome-card h3{font-family:var(--font-medieval);font-size:1.5rem;color:var(--brass-light);margin-bottom:.5rem}.welcome-card p{font-family:var(--font-tech);color:var(--text-secondary);font-size:1rem}.welcome-card .guild-motto{font-family:var(--font-mono);font-size:.85rem;color:var(--neon-cyan-dim);margin-top:1rem;padding-top:1rem;border-top:1px solid var(--copper-dark);font-style:italic;opacity:.8}.quick-actions{display:flex;gap:1rem;margin-top:1.5rem;flex-wrap:wrap}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.feature-card{position:relative;background:linear-gradient(135deg,#12121af2,#151a18f2);border:1px solid var(--copper-dark);border-radius:8px;padding:1.5rem;transition:all .3s ease;cursor:pointer}.feature-card:hover{border-color:var(--brass-primary);transform:translateY(-4px);box-shadow:0 8px 30px #0006,0 0 30px #c9a2271a}.feature-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--brass-primary),var(--neon-cyan));opacity:0;transition:opacity .3s ease}.feature-card:hover:before{opacity:1}.feature-icon{width:48px;height:48px;margin-bottom:1rem;color:var(--brass-primary);transition:all .3s ease}.feature-card:hover .feature-icon{color:var(--neon-cyan);filter:drop-shadow(0 0 8px var(--neon-cyan))}.feature-card h4{font-family:var(--font-medieval);font-size:1.1rem;color:var(--text-primary);margin-bottom:.5rem}.feature-card p{font-family:var(--font-tech);font-size:.9rem;color:var(--text-secondary);line-height:1.5}.gear-decor{position:absolute;opacity:.05;color:var(--brass-primary);pointer-events:none}.gear-decor.large{width:200px;height:200px}.gear-decor.medium{width:120px;height:120px}.gear-decor.small{width:60px;height:60px}.gear-decor.spinning{animation:rotate-slow 30s linear infinite}.gear-decor.spinning-reverse{animation:rotate-reverse 25s linear infinite}.divider-ornate{display:flex;align-items:center;gap:1rem;margin:2rem 0}.divider-ornate:before,.divider-ornate:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--copper-dark),var(--brass-primary),var(--copper-dark),transparent)}.divider-ornate span{font-family:var(--font-medieval);font-size:.8rem;color:var(--brass-primary);letter-spacing:.2em;text-transform:uppercase}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-family:var(--font-tech);font-size:.85rem;font-weight:600;color:var(--brass-light);letter-spacing:.05em;text-transform:uppercase;margin-bottom:.5rem}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;font-family:var(--font-tech);font-size:.95rem;color:var(--text-primary);background:#0a0a0ccc;border:1px solid var(--copper-dark);border-radius:4px;transition:all .2s ease}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--neon-cyan);box-shadow:0 0 0 2px #9b59f01a,0 0 15px #9b59f01a}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-secondary);opacity:.6}.form-group textarea{resize:vertical;min-height:100px}.form-subtitle{font-family:var(--font-mono);font-size:.8rem;color:var(--text-secondary);margin-bottom:1.5rem}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--copper-dark)}.events-page{position:relative}.create-event-form{margin-bottom:2rem}.create-event-form h3{margin-bottom:.25rem}.events-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:linear-gradient(135deg,#12121a80,#151a1880);border:1px dashed var(--copper-dark);border-radius:12px}.empty-state .empty-icon{width:64px;height:64px;color:var(--brass-primary);opacity:.5;margin-bottom:1.5rem}.empty-state h3{font-family:var(--font-medieval);font-size:1.5rem;color:var(--brass-light);margin-bottom:.5rem}.empty-state p{font-family:var(--font-tech);color:var(--text-secondary);margin-bottom:1.5rem;max-width:400px}.event-list{display:flex;flex-direction:column;gap:1rem}.event-card{display:flex;gap:1.5rem;padding:0;overflow:hidden}.event-date-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;min-width:100px;background:linear-gradient(135deg,#c9a22726,#b873331a);border-right:1px solid var(--copper-dark)}.event-date-badge .event-icon{width:24px;height:24px;color:var(--brass-primary);margin-bottom:.5rem}.event-date-badge .event-date{font-family:var(--font-tech);font-size:.85rem;font-weight:600;color:var(--brass-light);text-align:center;line-height:1.3}.event-content{flex:1;padding:1.5rem 1.5rem 1.5rem 0}.event-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.75rem}.event-header h3{font-family:var(--font-medieval);font-size:1.25rem;color:var(--text-primary);margin:0}.event-time{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.8rem;color:var(--neon-cyan);white-space:nowrap}.event-time .time-icon{width:14px;height:14px}.event-description{font-family:var(--font-tech);font-size:.9rem;color:var(--text-secondary);line-height:1.5;margin-bottom:1rem}.event-roster{display:flex;gap:1.5rem;padding-top:1rem;border-top:1px solid var(--copper-dark)}.roster-stat{display:flex;align-items:center;gap:8px}.roster-stat .roster-icon{width:18px;height:18px;color:var(--neon-cyan)}.roster-stat.attending .roster-count{color:var(--neon-cyan)}.roster-stat.tentative .roster-count{color:var(--neon-amber)}.roster-count{font-family:var(--font-medieval);font-size:1.25rem;font-weight:700}.roster-label{font-family:var(--font-mono);font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.btn-icon{width:18px;height:18px}@media(max-width:768px){.dashboard-container{flex-direction:column}.sidebar{width:100%;min-height:auto;border-right:none;border-bottom:1px solid var(--copper-dark)}.sidebar nav ul{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;padding:.5rem}.sidebar nav li{margin:0}.nav-section-title{display:none}.user-profile{justify-content:center}.home-container h1{font-size:2rem}.content-header,.dashboard-content{padding:1rem}.stats-grid{grid-template-columns:1fr 1fr}.feature-grid{grid-template-columns:1fr}}@media(max-width:480px){.home-container h1{font-size:1.5rem;letter-spacing:.05em}.stats-grid{grid-template-columns:1fr}.quick-actions{flex-direction:column}.quick-actions .btn{width:100%}}.user-profile-section{margin-top:auto;border-top:1px solid var(--copper-dark);position:relative;background:linear-gradient(180deg,transparent,rgba(10,10,12,.5))}.user-profile-section:before{content:"";position:absolute;top:0;left:1.5rem;right:1.5rem;height:1px;background:linear-gradient(90deg,transparent,var(--brass-primary),transparent)}.user-profile-section .user-profile{border-top:none;margin-top:0;background:transparent}.user-profile-section .user-profile:before{display:none}.btn-bnet-sidebar{display:flex;align-items:center;justify-content:center;gap:8px;margin:0 1rem 1rem;padding:10px 16px;font-family:var(--font-tech);font-size:.8rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-primary);background:linear-gradient(135deg,#00aaff26,#1e88e51a);border:1px solid #1e88e5;border-radius:4px;text-decoration:none;transition:all .2s ease}.btn-bnet-sidebar:hover{background:linear-gradient(135deg,#00aaff40,#1e88e533);border-color:#42a5f5;box-shadow:0 0 15px #1e88e54d;color:#42a5f5;text-shadow:0 0 8px rgba(30,136,229,.5)}.btn-bnet-sidebar .bnet-icon{width:16px;height:16px}.profile-page{position:relative}.profile-section{margin-bottom:2rem}.profile-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.profile-header .profile-icon{width:48px;height:48px;color:var(--brass-primary);flex-shrink:0}.profile-header h3{margin-bottom:.25rem}.profile-subtitle{font-family:var(--font-tech);font-size:.9rem;color:var(--text-secondary);margin:0}.btn-bnet{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 24px;font-family:var(--font-tech);font-size:.95rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-primary);background:linear-gradient(135deg,#0af3,#1e88e526);border:2px solid #1e88e5;border-radius:4px;cursor:pointer;transition:all .3s ease}.btn-bnet:hover{background:linear-gradient(135deg,#00aaff4d,#1e88e540);border-color:#42a5f5;box-shadow:0 0 20px #1e88e566;color:#42a5f5;transform:translateY(-2px)}.btn-bnet .btn-icon{width:20px;height:20px}.battletag-display{display:inline-flex;align-items:center;gap:10px;padding:12px 20px;background:linear-gradient(135deg,#9b59f01a,#7b3fbe0d);border:1px solid var(--neon-cyan-dim);border-radius:4px}.battletag-display .btn-icon{width:20px;height:20px;color:var(--neon-cyan)}.battletag{font-family:var(--font-tech);font-size:1rem;font-weight:600;color:var(--neon-cyan)}.character-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.character-card{padding:1.25rem}.character-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--copper-dark)}.character-header .char-icon{width:32px;height:32px;color:var(--brass-primary);flex-shrink:0}.character-name{font-family:var(--font-medieval);font-size:1.1rem;font-weight:600;margin:0 0 .25rem}.character-realm{font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary);letter-spacing:.05em}.character-stats{display:flex;flex-wrap:wrap;gap:1rem}.char-stat{display:flex;align-items:center;gap:6px;font-family:var(--font-tech);font-size:.85rem;color:var(--text-secondary)}.char-stat .class-icon{width:16px;height:16px;color:var(--brass-primary)}.char-stat .stat-label{font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;opacity:.7}.char-stat .stat-value{font-weight:600;color:var(--text-primary)}.char-stat .stat-value.ilvl{color:var(--neon-cyan)}.event-details-page{padding:0}.event-details-loading,.event-details-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem}.event-details-error{text-align:center}.event-details-error .icon{width:64px;height:64px;color:#f87171}.event-details-error h3{margin:0;color:#e0e0e0}.event-details-error p{color:#888;margin:.5rem 0 1.5rem}.event-info-card{margin-bottom:2rem}.event-info-card h3{margin-bottom:1rem;color:#c9a227}.event-description{color:#b0b0b0;line-height:1.6;margin-bottom:1.5rem}.event-meta{display:flex;gap:2rem;flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:.5rem;color:#888}.meta-item .icon{width:20px;height:20px}.rsvp-sections{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.rsvp-card{border-left:4px solid}.attending-card{border-left-color:#4ade80}.late-card{border-left-color:#fbbf24}.absent-card{border-left-color:#f87171}.tentative-card{border-left-color:#60a5fa}.rsvp-card h3{margin-bottom:1rem;font-size:1.1rem}.rsvp-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.rsvp-item{display:flex;flex-direction:column;gap:.25rem;padding:.5rem;background:#ffffff05;border-radius:4px}.rsvp-username{font-weight:600;color:#e0e0e0}.rsvp-character{font-size:.9rem;font-weight:500}.rsvp-role{font-size:.85rem;color:#888;text-transform:uppercase}.officer-card{border:1px solid #c9a227;background:linear-gradient(135deg,#c9a2270d,#9b59f008)}.officer-card h3{display:flex;align-items:center;gap:.75rem;color:#c9a227;margin-bottom:1rem}.officer-card h3 .icon{width:24px;height:24px}.empty-message{color:#888;text-align:center;padding:2rem;font-style:italic}.missing-signups-card{margin-bottom:1.5rem}.missing-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:.75rem}.missing-item{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:#f871711a;border-left:3px solid #f87171;border-radius:4px}.missing-username{font-weight:600;color:#e0e0e0}.missing-character{font-size:.9rem;font-weight:500}.attendance-stats-card{margin-bottom:2rem}.attendance-table-wrapper{overflow-x:auto}.attendance-table{width:100%;border-collapse:collapse}.attendance-table thead{background:#ffffff0d}.attendance-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:#c9a227;border-bottom:2px solid #333}.attendance-table td{padding:.75rem 1rem;border-bottom:1px solid #222}.attendance-table tbody tr:hover{background:#ffffff08}.player-cell{font-weight:600;color:#e0e0e0}.characters-cell{display:flex;flex-wrap:wrap;gap:.5rem}.character-tag{font-size:.85rem;font-weight:500;padding:.25rem .5rem;background:#ffffff0d;border-radius:3px}.attendance-cell{min-width:200px}.attendance-bar-container{position:relative;width:100%;height:28px;background:#ffffff0d;border-radius:4px;overflow:hidden}.attendance-bar{position:absolute;top:0;left:0;height:100%;transition:width .3s ease;border-radius:4px}.attendance-percentage{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-weight:600;font-size:.9rem;z-index:1;text-shadow:0 1px 2px rgba(0,0,0,.8)}@media(max-width:768px){.rsvp-sections{grid-template-columns:1fr}.event-meta{flex-direction:column;gap:1rem}.missing-list{grid-template-columns:1fr}.attendance-table th,.attendance-table td{padding:.5rem;font-size:.9rem}.attendance-cell{min-width:150px}.characters-cell{flex-direction:column}}.roster-card{background:#1a1a1a;border:2px solid;border-radius:8px;padding:1rem;display:flex;flex-direction:column;gap:1rem;transition:transform .2s,box-shadow .2s}.roster-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.roster-card-header{display:flex;align-items:center;gap:1rem}.char-thumbnail{width:64px;height:64px;border-radius:8px;object-fit:cover;border:2px solid #333}.char-info{flex:1}.char-info h3{margin:0 0 .25rem;font-size:1.25rem;font-weight:600}.char-realm{margin:0;color:#888;font-size:.875rem}.char-spec{margin:.25rem 0 0;color:#b0b0b0;font-size:.875rem}.roster-card-body{display:flex;flex-direction:column;gap:.75rem}.role-badges{display:flex;gap:.5rem;flex-wrap:wrap}.role-badge{padding:.25rem .75rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.role-tank{background:#3b82f633;color:#60a5fa;border:1px solid #3b82f6}.role-healer{background:#22c55e33;color:#4ade80;border:1px solid #22c55e}.role-dps{background:#ef444433;color:#f87171;border:1px solid #ef4444}.category-badge{padding:.25rem .75rem;border-radius:4px;font-size:.75rem;font-weight:500;background:#b8860b33;color:#d4a574;border:1px solid #b8860b}.char-stats{display:flex;gap:1.5rem}.stat{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.75rem;color:#888;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:1.125rem;font-weight:600;color:#e0e0e0}.attendance-stat{border-left:2px solid #333;padding-left:1rem}.attendance-value{font-weight:700;text-shadow:0 0 8px currentColor}.char-discord{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#5865f21a;border-radius:4px;border:1px solid rgba(88,101,242,.3)}.discord-icon{font-size:1rem}.discord-user{font-size:.875rem;color:#b0b0b0}.char-links{display:flex;gap:.5rem;padding:.5rem 0}.char-link{flex:1;text-align:center;padding:.4rem .75rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;text-decoration:none;transition:all .2s;border:1px solid}.armory-link{background:#ffd7001a;color:gold;border-color:#c9a227}.armory-link:hover{background:#ffd70033;box-shadow:0 0 10px #ffd7004d}.rio-link{background:#9b59f01a;color:#9b59f0;border-color:#7b3fbe}.rio-link:hover{background:#9b59f033;box-shadow:0 0 10px #9b59f04d}.wcl-link{background:#3b82f61a;color:#60a5fa;border-color:#3b82f6}.wcl-link:hover{background:#3b82f633;box-shadow:0 0 10px #3b82f64d}.roster-card-actions{display:flex;gap:.5rem;padding-top:.5rem;border-top:1px solid #333}.btn-refresh,.btn-remove{flex:1;padding:.5rem;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid}.btn-refresh{background:#3b82f61a;color:#60a5fa;border-color:#3b82f6}.btn-refresh:hover{background:#3b82f633}.btn-remove{background:#ef44441a;color:#f87171;border-color:#ef4444}.btn-remove:hover{background:#ef444433}.user-picker-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.user-picker-modal{background:#1a1a1a;border:1px solid #333;border-radius:8px;width:90%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000080}.user-picker-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #333}.user-picker-header h3{margin:0;color:#e0e0e0;font-size:1.2rem}.close-btn{background:none;border:none;color:#888;font-size:2rem;cursor:pointer;padding:0;line-height:1;transition:color .2s}.close-btn:hover{color:#e0e0e0}.user-picker-search{padding:1rem 1.5rem;border-bottom:1px solid #333}.user-picker-search input{width:100%;padding:.75rem;background:#0f0f0f;border:1px solid #333;border-radius:4px;color:#e0e0e0;font-size:1rem}.user-picker-search input:focus{outline:none;border-color:#b8860b}.user-picker-content{flex:1;overflow-y:auto;padding:.5rem}.members-list{display:flex;flex-direction:column;gap:.25rem}.member-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-radius:4px;cursor:pointer;transition:background .2s}.member-item:hover{background:#252525}.member-item.selected{background:#2a2a1a;border:1px solid #b8860b}.member-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.member-info{flex:1}.member-display-name{color:#e0e0e0;font-weight:500;margin-bottom:.25rem}.member-username{color:#888;font-size:.875rem}.loading,.error,.no-results{text-align:center;padding:2rem;color:#888}.error{color:#ff6b6b}.roster-form-card{margin-bottom:2rem}.roster-form-card h3{margin:0 0 1.5rem;color:#e0e0e0}.roster-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:#b0b0b0;font-size:.875rem;font-weight:500}.form-group input{padding:.75rem;background:#0f0f0f;border:1px solid #333;border-radius:4px;color:#e0e0e0;font-size:1rem}.form-group input:focus{outline:none;border-color:#b8860b}.user-select-btn{padding:.75rem;background:#0f0f0f;border:1px solid #333;border-radius:4px;color:#e0e0e0;text-align:left;cursor:pointer;transition:all .2s;font-size:1rem}.user-select-btn:hover{border-color:#b8860b;background:#1a1a1a}.form-error{padding:.75rem;background:#ef44441a;border:1px solid #ef4444;border-radius:4px;color:#f87171;font-size:.875rem}.form-actions{display:flex;justify-content:flex-end;padding-top:.5rem}.composition-banner{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem;padding:1.5rem;background:linear-gradient(135deg,#b8860b1a,#00ffff1a);border:1px solid rgba(184,134,11,.3);border-radius:8px}.comp-stat{text-align:center}.comp-number{font-size:2.5rem;font-weight:700;color:#b8860b;line-height:1;margin-bottom:.5rem}.comp-label{font-size:.875rem;color:#e0e0e0;font-weight:600;text-transform:uppercase;letter-spacing:1px}.comp-sublabel{font-size:.75rem;color:#888;margin-top:.25rem}.comp-total .comp-number{color:#0ff}.roster-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.loading-state,.error-state{text-align:center;padding:3rem;color:#888}.error-state{color:#f87171}.empty-state{text-align:center;padding:4rem 2rem}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state h3{color:#e0e0e0;margin:0 0 .5rem;font-size:1.5rem}.empty-state p{color:#888;margin:0 0 2rem;font-size:1rem}@media(max-width:768px){.form-row{grid-template-columns:1fr}.composition-banner{grid-template-columns:repeat(2,1fr)}.roster-grid{grid-template-columns:1fr}}.alt-roster-form-card{margin-bottom:2rem;border:1px solid rgba(147,51,234,.3)}.alt-roster-form-card h3{margin:0 0 1.5rem;color:#e0e0e0}.alt-composition{background:linear-gradient(135deg,#9333ea1a,#3b82f61a);border:1px solid rgba(147,51,234,.3)}.alt-roster-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.alt-roster-card{background:#1a1a1a;border:2px solid;border-radius:8px;padding:1rem;display:flex;flex-direction:column;gap:1rem;transition:transform .2s,box-shadow .2s;position:relative}.alt-roster-card:before{content:"";position:absolute;top:8px;right:8px;width:8px;height:8px;background:#9333ea99;border-radius:50%;box-shadow:0 0 8px #9333eacc}.alt-roster-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.alt-card-header{display:flex;align-items:center;gap:1rem}.alt-card-body{display:flex;flex-direction:column;gap:.75rem}.owner-info{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#9333ea1a;border-radius:4px;border:1px solid rgba(147,51,234,.3)}.owner-icon{font-size:1rem}.owner-name{font-size:.875rem;color:#c084fc;font-weight:500}.alt-card-actions{display:flex;gap:.5rem;padding-top:.5rem;border-top:1px solid #333}.alt-card-actions .btn-remove{flex:1;padding:.5rem;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid;background:#ef44441a;color:#f87171;border-color:#ef4444}.alt-card-actions .btn-remove:hover{background:#ef444433}@media(max-width:768px){.alt-roster-grid{grid-template-columns:1fr}}
