.server-status-notification{position:fixed;top:20px;right:20px;padding:12px 16px;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.15);z-index:1000;display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;max-width:350px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.status-connecting{background:linear-gradient(135deg,rgba(47,74,114,.9),rgba(31,61,82,.9));color:#D4B67A;border-color:rgba(212,182,122,.3)}.status-error{background:linear-gradient(135deg,rgba(220,53,69,.9),rgba(153,27,27,.9));color:white;border-color:rgba(220,53,69,.3)}.status-warning{background:linear-gradient(135deg,rgba(255,193,7,.9),rgba(153,139,95,.9));color:#0E2C40;border-color:rgba(255,193,7,.3)}.status-icon{font-size:16px;animation:pulse 2s infinite}.status-connecting .status-icon{animation:spin 1s linear infinite}.status-message{flex:1 1;line-height:1.4}.retry-button{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);color:inherit;padding:6px 12px;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.retry-button:hover{background:rgba(255,255,255,.3);transform:translateY(-1px)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.server-status-notification{top:10px;right:10px;left:10px;max-width:none;font-size:13px}}*{box-sizing:border-box;margin:0;padding:0}body,html{max-width:100vw;overflow-x:hidden;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;background:linear-gradient(135deg,#2F4A72,#0E2C40);min-height:100vh;color:#333}.navbar{background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:none;border-bottom:1px solid rgba(255,255,255,.2);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;position:-webkit-sticky;position:sticky;top:0;z-index:1000;box-shadow:0 8px 32px rgba(0,0,0,.1)}.navbar-brand{font-size:1.5rem;font-weight:700;color:white;text-decoration:none;text-shadow:0 2px 4px rgba(0,0,0,.3)}.navbar-links{display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap}.navbar-link{color:rgba(255,255,255,.9);text-decoration:none;padding:.5rem 1rem;border-radius:8px;transition:all .3s ease;font-weight:500;border:1px solid transparent}.navbar-link:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);color:white;transform:translateY(-1px)}.navbar-link.admin{background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:white;font-weight:600}.navbar-link.admin:hover{background:linear-gradient(135deg,#ee5a24,#ff6b6b);transform:translateY(-2px);box-shadow:0 4px 15px rgba(238,90,36,.4)}.page-container{max-width:1400px;margin:0 auto;padding:2rem 1rem;min-height:calc(100vh - 80px)}.dashboard-page .page-container{max-width:95vw;padding:1.5rem .5rem}.dashboard-grid{display:grid;grid-template-columns:1fr 2fr 1fr;grid-gap:1.5rem;gap:1.5rem;margin-top:1.5rem;align-items:start;width:100%}@media (max-width:1200px){.dashboard-grid{grid-template-columns:1fr 1.5fr 1fr;gap:1rem}}@media (max-width:900px){.dashboard-grid{grid-template-columns:1fr;gap:1rem}}.dashboard-section{background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:1.5rem;box-shadow:0 8px 32px rgba(0,0,0,.1);transition:all .3s ease}.dashboard-section:hover{transform:translateY(-5px);box-shadow:0 12px 40px rgba(0,0,0,.15);border-color:rgba(255,255,255,.3)}.dashboard-section h3{color:white;font-size:1.3rem;font-weight:600;margin-bottom:1rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.character-card{background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:1.5rem;box-shadow:0 8px 32px rgba(0,0,0,.1);transition:all .3s ease;max-width:300px;margin:1rem}.character-card:hover{transform:translateY(-5px);box-shadow:0 12px 40px rgba(0,0,0,.15);border-color:rgba(255,255,255,.3)}.character-card img{width:100%;height:150px;object-fit:cover;border-radius:12px;margin-bottom:1rem;border:2px solid rgba(255,255,255,.2)}.character-card h3{color:white;font-size:1.2rem;font-weight:600;margin-bottom:.5rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.character-card p{color:rgba(255,255,255,.9);margin-bottom:.5rem;font-size:.9rem}.character-card strong{color:white;font-weight:600}.character-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:1.5rem;gap:1.5rem;margin-top:2rem}.session-dashboard-container{background:rgba(255,255,255,.05);border-radius:12px;padding:1rem;border:1px solid rgba(255,255,255,.1);width:100%;overflow-x:auto}.session-dashboard-container .session-container{background:transparent;padding:0;margin:0;width:100%}.session-dashboard-container .session-header{display:none}.session-dashboard-container .sessions-table{margin-top:0;width:100%;min-width:600px}.session-dashboard-container .table-container{width:100%;overflow-x:auto}.session-dashboard-container .action-buttons{display:flex;flex-wrap:wrap;gap:.3rem;justify-content:center}.session-dashboard-container .action-button{font-size:.8rem;padding:.4rem .8rem;min-width:auto}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;text-decoration:none;display:inline-block;text-align:center;transition:all .3s ease;cursor:pointer;font-size:.9rem;margin:.25rem;min-width:80px}.btn-primary{background:linear-gradient(135deg,#2F4A72,#0E2C40);color:white;border:none;font-weight:600}.btn-primary:hover{background:linear-gradient(135deg,#0E2C40,#2F4A72);transform:translateY(-2px)}.btn-secondary{background:linear-gradient(135deg,#998B5F,#D4B67A);color:white;border:none;font-weight:600}.btn-secondary:hover{background:linear-gradient(135deg,#D4B67A,#998B5F);transform:translateY(-2px)}.btn-success{background:linear-gradient(135deg,#4ecdc4,#44a08d);color:white;border:none;font-weight:600}.btn-success:hover{background:linear-gradient(135deg,#44a08d,#4ecdc4);transform:translateY(-2px)}.btn-danger{background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:white;border:none;font-weight:600}.btn-danger:hover{background:linear-gradient(135deg,#ee5a24,#ff6b6b);transform:translateY(-2px)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important;box-shadow:none!important}.card{background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:1.5rem;box-shadow:0 8px 32px rgba(0,0,0,.1);transition:all .3s ease}.card:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.15);border-color:rgba(255,255,255,.3)}.page-header{text-align:center;margin-bottom:3rem}.page-header h1{color:white;font-size:2.5rem;font-weight:700;margin-bottom:.5rem;text-shadow:0 4px 8px rgba(0,0,0,.3)}.page-header h2{color:white;font-size:2rem;font-weight:600;margin-bottom:.5rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.page-header p{color:rgba(255,255,255,.8);font-size:1.1rem;max-width:600px;margin:0 auto}.loading{color:rgba(255,255,255,.8);font-size:1.2rem}.error,.loading{text-align:center;padding:2rem}.error{color:#ff6b6b;font-size:1.1rem;background:rgba(255,107,107,.1);border:1px solid rgba(255,107,107,.3);border-radius:8px;margin:1rem 0}.online-users{background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:1.5rem}.online-users h3{color:white;margin-bottom:1rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.user-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.75rem;margin-bottom:.5rem;transition:all .3s ease;cursor:pointer}.user-card:hover{background:rgba(255,255,255,.1);transform:translateX(5px)}.user-card.current-user{border-color:rgba(78,205,196,.5);background:rgba(78,205,196,.1)}a{color:rgba(255,255,255,.9);text-decoration:none;transition:color .3s ease}a:hover{color:white;text-decoration:underline}@media (max-width:768px){.navbar{padding:1rem;flex-direction:column}.navbar,.navbar-links{gap:1rem}.page-container{padding:1rem .5rem}.dashboard-page .page-container{padding:1rem .25rem}.dashboard-grid{grid-template-columns:1fr;gap:1rem}.character-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.page-header h1{font-size:2rem}.page-header h2{font-size:1.5rem}.session-dashboard-container .sessions-table{min-width:500px;font-size:.85rem}.session-dashboard-container .action-button{font-size:.75rem;padding:.3rem .6rem}}