*{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.button{background:none;cursor:pointer;font-family:inherit;font-size:inherit}.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-no-characters{color:rgba(255,255,255,.8);margin-bottom:1rem}.home-journey-card{max-width:600px;margin:0 auto;text-align:center}.home-journey-title{color:white;margin-bottom:1rem}.home-journey-text{color:rgba(255,255,255,.8);margin-bottom:2rem}.home-journey-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.user-card-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);margin-right:1rem;display:flex;align-items:center;justify-content:center;color:white;font-weight:600;font-size:1.1rem}.user-card-info{flex:1 1}.user-card-username{color:white;margin-bottom:.25rem}.user-card-username.current-user{font-weight:600}.user-card-username.other-user{font-weight:500}.user-card-location{font-size:.75rem;color:rgba(255,255,255,.7);cursor:pointer;text-decoration:underline}.online-users-list{max-height:400px;overflow-y:auto}.no-users-card{text-align:center}.no-users-text{color:rgba(255,255,255,.7)}.user-online-users-container{max-height:500px;overflow-y:auto}.user-online-users-border{border:1px solid #e3e6f0;border-radius:0 0 8px 8px;padding:.5rem}.user-no-users-text{padding:1rem;text-align:center}.user-card-container{display:flex;align-items:center;padding:.75rem;margin-bottom:.5rem;background-color:#f8f9fa;border-radius:8px;border-left:4px solid transparent}.user-card-container.current-user{border-left:4px solid rgb(0,0,1)}.user-card-avatar-user{width:40px;height:40px;border-radius:50%;background-color:#ddd;margin-right:1rem;display:flex;align-items:center;justify-content:center;overflow:hidden}.user-card-avatar-text{font-size:18px;color:#666}.user-card-username-text{font-weight:500}.user-card-username-text.current-user{font-weight:600}.user-card-location-text{font-size:.75rem;color:#6c757d}.map-page-container{position:relative;padding:2rem;background-color:#b7abab}.map-image-container{position:relative}.map-image{width:100%;height:auto}.map-location-button{position:absolute;background:red;color:white;border:none;border-radius:50%;padding:5px;cursor:pointer}.protected-page-container{padding:2rem}.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)}img .character-img{height:500px}.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}.active-character-banner{background:rgba(0,255,0,.1);border:1px solid rgba(0,255,0,.3);border-radius:8px;padding:.75rem;margin-top:.5rem;margin-bottom:1rem}.active-character-name{color:#4ade80}.npc-badge{color:#fbbf24;margin-left:.5rem}.empty-state-card{text-align:center;max-width:600px;margin:0 auto}.empty-state-card h3{color:white;margin-bottom:1rem}.empty-state-card p{color:rgba(255,255,255,.8);margin-bottom:1.5rem}.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}}