@import"https://fonts.googleapis.com/css2?family=Roboto+Condensed:wght@300;400;700&display=swap";.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 16px}.login-frame{width:100%;max-width:440px;background:linear-gradient(145deg,#0e1523eb,#121a2ce6);border:1px solid rgba(148,163,184,.18);border-radius:16px;padding:28px 26px 24px;box-shadow:0 15px 45px #0006,0 0 0 1px #3b82f614;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.login-header{display:flex;align-items:center;gap:12px;margin-bottom:18px}.login-icon{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,#3b82f62e,#ec48992e);border:1px solid rgba(148,163,184,.25);display:grid;place-items:center;font-size:20px}.login-header h1{margin:0;font-size:1.6rem;color:#f8fafc;letter-spacing:.5px}.status-text{margin:2px 0 0;font-size:.95rem;color:#9ca3af}.login-form{display:flex;flex-direction:column;gap:14px}@media(max-width:520px){.login-frame{padding:24px 20px 20px}.login-header h1{font-size:1.45rem}}body{background:radial-gradient(1400px 900px at 10% 10%,rgba(59,130,246,.08),transparent),radial-gradient(900px 700px at 90% 20%,rgba(236,72,153,.07),transparent),#0b0f1a;color:#e5e7eb}.register-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 16px}.register-frame{width:100%;max-width:480px;background:linear-gradient(145deg,#0e1523eb,#121a2ce6);border:1px solid rgba(148,163,184,.18);border-radius:16px;padding:28px 26px 24px;box-shadow:0 15px 45px #0006,0 0 0 1px #3b82f614;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.register-header{display:flex;align-items:center;gap:12px;margin-bottom:18px}.register-icon{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,#3b82f62e,#ec48992e);border:1px solid rgba(148,163,184,.25);display:grid;place-items:center;font-size:20px}.register-header h1{margin:0;font-size:1.6rem;color:#f8fafc;letter-spacing:.5px}.alert{padding:12px 14px;border-radius:10px;border:1px solid rgba(248,113,113,.4);background:#f871711a;color:#fecdd3;font-size:.95rem;margin-bottom:14px}.register-form{display:flex;flex-direction:column;gap:14px}.field{display:flex;flex-direction:column;gap:6px}.field span{font-size:.95rem;color:#cbd5e1;letter-spacing:.2px}.field input{width:100%;padding:12px 14px;background:#0f172aa6;border:1px solid rgba(148,163,184,.2);border-radius:10px;color:#e5e7eb;font-size:1rem;transition:border-color .2s,box-shadow .2s,background .2s}.field input::-moz-placeholder{color:#94a3b899}.field input::placeholder{color:#94a3b899}.field input:focus{outline:none;border-color:#60a5fab3;box-shadow:0 0 0 3px #3b82f633;background:#0f172acc}.btn-primary{width:100%;margin-top:4px;padding:12px 14px;border:none;border-radius:10px;font-weight:700;font-size:1rem;letter-spacing:.4px;cursor:pointer;color:#0b1224;background:linear-gradient(135deg,#fbbf24,#f97316);box-shadow:0 10px 30px #f9731659,inset 0 1px #ffffff40;transition:transform .15s ease,box-shadow .15s ease}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 36px #f9731673,inset 0 1px #ffffff47}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.footer{margin-top:18px;display:flex;justify-content:center;gap:8px;font-size:.95rem;color:#9ca3af}.link{color:#fbbf24;font-weight:600;text-decoration:none;border-bottom:1px solid transparent;transition:color .2s,border-color .2s}.link:hover{color:#fcd34d;border-color:#fcd34d80}@media(max-width:520px){.register-frame{padding:24px 20px 20px}.register-header h1{font-size:1.45rem}}.campaigns-panel{padding:var(--spacing-2xl);max-width:1400px;margin:0 auto;color:var(--sky-text);font-family:inherit}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl)}.panel-header h2{font-size:28px;font-weight:700;color:var(--text-primary);margin:0;background:transparent;color:var(--sky-text)}.header-actions{display:flex;gap:12px}.btn-action{padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:none;transition:all .3s ease}.btn-create{background:var(--sky-accent-bg);color:var(--sky-accent-text);padding:10px 18px;border-radius:8px;font-weight:700;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;border:1px solid rgba(255,255,255,.04)}.btn-join{background:#ffffff0a;color:var(--sky-text);box-shadow:0 4px 12px #d1d1d10f}.btn-join:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f666}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--error-red);padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px}.loading,.empty-state{text-align:center;padding:60px 20px;color:var(--text-secondary)}.empty-subtitle{font-size:14px;margin-top:8px}.campaigns-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px;margin-bottom:24px}.campaign-card{background:transparent;border:1px solid var(--border-medium);border-radius:var(--radius-lg);padding:20px;cursor:pointer;transition:all .18s ease;box-shadow:var(--shadow-md)}.campaign-card:hover{transform:translateY(-4px);border-color:#ffffff14;box-shadow:0 8px 28px #0006}.campaign-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.campaign-header h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0;flex:1}.status-badge{padding:4px 12px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.active,.status-badge.paused{background:#ffffff08;color:var(--sky-text);border:1px solid rgba(209,209,209,.06)}.status-badge.completed{background:#ffffff05;color:var(--text-secondary);border:1px solid rgba(209,209,209,.04)}.campaign-description{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.campaign-meta{display:flex;gap:var(--spacing-lg);margin-bottom:12px;padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.meta-item{display:flex;gap:6px;font-size:12px}.meta-label{color:var(--text-secondary);font-weight:600}.meta-value{color:var(--text-primary)}.campaign-code{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#ffffff05;border:1px solid rgba(209,209,209,.06);border-radius:6px;margin-top:12px}.code-label{font-size:11px;color:var(--text-secondary);font-weight:600}.code-value{font-size:13px;color:var(--sky-text);font-family:Courier New,monospace;font-weight:700;letter-spacing:2px;flex:1}.btn-copy-code{background:#ffffff08;border:1px solid rgba(209,209,209,.06);color:var(--sky-text);padding:4px 8px;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:28px}.btn-copy-code:hover{background:#ffffff0d;transform:scale(1.02)}.btn-copy-code:active{transform:scale(.95)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background:var(--sky-bg);border-radius:var(--radius-xl);border:2px solid var(--border-medium);width:90%;max-width:500px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease;box-shadow:var(--shadow-lg);font-family:inherit}.modal-header{padding:20px 24px;border-bottom:1px solid rgba(148,163,184,.2);display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;font-size:20px;color:var(--text-primary)}.modal-close{background:none;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background:#ef44441a;color:var(--error-red)}.modal-body{padding:24px;overflow-y:auto}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.form-group input,.form-group textarea,.form-group select{width:100%;background:#0f172a99;border:1px solid rgba(148,163,184,.2);border-radius:8px;padding:10px 12px;color:var(--text-primary);font-size:14px;font-family:inherit;transition:all .2s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#d1d1d11f;box-shadow:0 0 0 3px #d1d1d10a}.form-group textarea{resize:vertical;min-height:80px}.info-text{font-size:13px;color:var(--sky-text);background:#ffffff05;padding:12px;border-radius:6px;border:1px solid rgba(209,209,209,.06);margin-top:12px}.modal-footer{padding:16px 24px;border-top:1px solid rgba(148,163,184,.2);display:flex;justify-content:flex-end;gap:12px}.btn-primary,.btn-secondary{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all .2s}.btn-primary{background:#ffffff0d;border:none;color:var(--sky-text);padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;box-shadow:0 4px 12px #d1d1d10f}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #d1d1d114}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#6b728033;color:var(--text-secondary);border:1px solid rgba(107,114,128,.3)}.btn-secondary:hover:not(:disabled){background:#6b72804d}.btn-refresh{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;border:1px solid rgba(148,163,184,.2);background:#1e293b80;color:var(--text-primary);transition:all .3s ease;display:block;margin:0 auto}.btn-refresh:hover:not(:disabled){background:#1e293bcc;border-color:#94a3b866}.btn-refresh:disabled{opacity:.5;cursor:not-allowed}.characters-panel{padding:var(--spacing-3xl);max-width:1400px;margin:0 auto;color:var(--sky-text);font-family:inherit}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-3xl)}.panel-header h2{font-size:28px;font-weight:700;color:var(--text-primary);margin:0}.btn-action{padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;box-shadow:var(--shadow-md),0 0 0 1px #a855f71a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:none;transition:all .3s ease}.btn-create{background:var(--sky-accent-bg);color:var(--sky-accent-text);padding:10px 18px;border-radius:8px;font-weight:700;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;border:1px solid rgba(255,255,255,.04);max-width:-moz-max-content;max-width:max-content}.btn-create:hover{transform:translateY(-2px);box-shadow:0 6px 18px #0009}.empty-state{text-align:center;padding:60px var(--spacing-xl);color:var(--text-secondary)}.empty-subtitle{font-size:14px;margin-top:var(--spacing-sm)}.characters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-3xl);margin-bottom:var(--spacing-3xl)}.character-card{background:transparent;border:1px solid var(--border-medium);border-radius:var(--radius-xl);padding:0;position:relative;overflow:hidden;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease;box-shadow:var(--shadow-md)}.character-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:#ffffff08;opacity:0;transition:opacity .3s ease}.character-card:hover{transform:translateY(-6px);border-color:#ffffff14;box-shadow:0 10px 28px #0006}.character-card:hover:before{opacity:1}.character-portrait{width:100%;height:200px;overflow:hidden;background:var(--sky-bg)}.character-portrait img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.character-info{padding:var(--spacing-xl)}.character-info h3{font-size:20px;font-weight:700;color:var(--text-primary);margin:0 0 var(--spacing-sm) 0}.character-details{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);font-size:14px;color:var(--text-secondary)}.detail-item{color:#d1d5db;font-weight:500}.detail-separator{color:var(--text-muted)}.character-stats{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.stat-badge{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:#ffffff05;border:1px solid var(--border-medium);border-radius:var(--radius-md);flex:1;min-width:70px;position:relative;overflow:hidden;transition:all .3s ease;box-shadow:none}.stat-badge:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:#ffffff08;transition:left .5s ease}.stat-badge:hover:before{left:100%}.stat-badge:hover{border-color:#d1d1d11f;box-shadow:0 0 10px #d1d1d10f;transform:translateY(-2px)}.stat-label{font-size:10px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-xs)}.stat-value{font-size:16px;color:var(--sky-text);font-weight:700;font-family:Courier New,monospace}.character-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--border-light)}.btn-edit-char,.btn-select-char,.btn-delete-char{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .2s ease;font-family:inherit}.btn-edit-char,.btn-select-char{flex:1}.btn-edit-char{background:#ffffff0a;border:none;color:var(--sky-text);padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;box-shadow:0 4px 12px #d1d1d10f}.btn-edit-char:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:#ffffff08;transition:left .5s ease}.btn-edit-char:hover:before{left:100%}.btn-edit-char:hover{transform:translateY(-2px);box-shadow:0 8px 20px #d1d1d114;background:#ffffff0d}.btn-select-char{background:#ffffff08;border:1px solid rgba(209,209,209,.06);color:var(--sky-text)}.btn-select-char:hover{background:#ffffff0d;border-color:#d1d1d11f}.btn-delete-char{background:#ffffff08;border:1px solid rgba(209,209,209,.06);color:var(--danger-red);min-width:44px}.btn-delete-char:hover:not(:disabled){background:#ffffff0f;border-color:#d1d1d11f;transform:translateY(-1px)}.btn-delete-char:disabled{opacity:.5;cursor:not-allowed}.btn-edit-char:disabled,.btn-select-char:disabled{opacity:.5;cursor:not-allowed}.btn-refresh{padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;border:1px solid var(--border-medium);background:#ffffff05;color:var(--sky-text);transition:all .3s ease;display:block;margin:0 auto}.btn-refresh:hover{background:#ffffff0d;border-color:#d1d1d11f}.dashboard-container{min-height:100vh;background:radial-gradient(1400px 900px at 10% 10%,rgba(59,130,246,.08),transparent),radial-gradient(900px 700px at 90% 20%,rgba(236,72,153,.07),transparent),#0b0f1a;display:flex;flex-direction:column;color:#e5e7eb;padding-top:20px}.dashboard-tabs{display:flex;gap:8px;padding:16px 24px;background:#0e152366;border-bottom:1px solid rgba(148,163,184,.15);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.tab-btn{padding:12px 24px;background:transparent;border:1px solid transparent;border-radius:8px;color:#cbd5e1d9;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.tab-btn:hover{color:#e5e7eb;background:#ffffff0d}.tab-btn.active{background:#3b82f626;color:#60a5fa;border-color:#3b82f64d;box-shadow:0 0 12px #3b82f633}.page-header h2{font-size:2rem;font-weight:700;margin:0;color:#f8fafc;letter-spacing:.5px}.btn-create-primary{background:linear-gradient(135deg,#fbbf24,#f97316);color:#0b1224;padding:12px 24px;border-radius:10px;font-weight:700;font-size:.95rem;cursor:pointer;transition:all .2s ease;border:none;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 6px 20px #f973164d,inset 0 1px #ffffff40}.btn-create-primary:hover{transform:translateY(-2px);box-shadow:0 10px 28px #f9731666,inset 0 1px #ffffff4d}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:20px}.loading-state p{color:#e5e7eb;font-size:1.1rem;font-weight:500}.error-state{background:#f5576c14;border:1px solid rgba(245,87,108,.12);border-radius:12px;padding:30px;text-align:center;min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px}.error-state p{color:#f5576ce6;font-size:1.1rem;margin:0}.btn-retry{background:#ffffff0f;color:var(--sky-text);border:none;padding:10px 20px;border-radius:6px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-retry:hover{background:#ffffff14}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:20px;text-align:center;background:#ffffff05;border:2px dashed rgba(209,209,209,.06);border-radius:12px}.empty-icon{font-size:4rem;opacity:.7}.empty-state h3{font-size:1.5rem;color:var(--sky-text);margin:0}.empty-state p{color:var(--text-secondary);font-size:1rem;margin:0}.btn-create-secondary{background:#ffffff0f;color:var(--sky-text);border:none;padding:12px 30px;border-radius:8px;font-weight:700;cursor:pointer;transition:all .3s ease;font-size:1rem}.btn-create-secondary:hover{box-shadow:0 6px 16px #0009;transform:translateY(-2px)}.characters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:25px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.character-card{background:linear-gradient(145deg,#0e1523bf,#121a2cb3);border:1px solid rgba(148,163,184,.15);border-radius:12px;overflow:hidden;transition:all .3s ease;display:flex;flex-direction:column;height:100%;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 4px 16px #0000004d}.character-card:hover{transform:translateY(-5px);box-shadow:0 12px 40px #0006,0 0 0 1px #3b82f633;border-color:#60a5fa66;background:linear-gradient(145deg,#0e1523d9,#121a2ccc);border-radius:16px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.character-image{width:100%;height:200px;background:#ffffff05;overflow:hidden;display:flex;align-items:center;justify-content:center}.character-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.character-image-placeholder{width:100%;height:200px;background:#ffffff05;display:flex;align-items:center;justify-content:center;border-bottom:2px solid rgba(209,209,209,.06)}.placeholder-icon{font-size:5rem;opacity:.5}.character-info{padding:20px;flex:1;display:flex;flex-direction:column;gap:12px}.character-name{font-size:1.3rem;font-weight:700;margin:0;color:#f8fafc;line-height:1.4;letter-spacing:.3px}.character-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.stat{background:#ffffff05;padding:10px;border-radius:6px;text-align:center;border-left:3px solid rgba(209,209,209,.06)}.stat-label{display:block;font-size:.85rem;color:#cbd5e1cc;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.stat-value{display:block;font-size:1.15rem;font-weight:700;color:#60a5fa;font-family:Monaco,Courier New,monospace}.character-health{margin:10px 0}.health-bar{width:100%;height:8px;background:#0000004d;border-radius:4px;overflow:hidden;margin-bottom:5px}.health-fill{height:100%;background:var(--sky-accent-bg, rgba(255,255,255,.06));transition:width .3s ease}.health-text{font-size:.9rem;color:var(--text-secondary)}.character-backstory{font-size:.9rem;color:var(--text-secondary);line-height:1.4;margin:8px 0 0;font-style:italic;max-height:60px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.character-actions{padding:15px 20px;border-top:1px solid rgba(0,212,255,.2);display:flex;gap:10px}.btn-play{flex:1;background:#ffffff0f;color:var(--sky-text);border:none;padding:10px 15px;border-radius:6px;font-weight:700;cursor:pointer;transition:all .3s ease;font-size:.95rem}.btn-play:hover{box-shadow:0 6px 16px #0009;transform:translateY(-2px)}.btn-delete{background:#e9456033;color:var(--error-red-light);border:1px solid var(--error-red-light);padding:10px 15px;border-radius:6px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.9rem}.btn-delete:hover{background:var(--primary-pink);color:var(--text-primary);box-shadow:0 8px 20px #e9456066;transform:translateY(-2px)}@media(max-width:768px){.header-content{flex-direction:column;gap:15px}.page-header{flex-direction:column;align-items:stretch}.btn-create-primary{width:100%}.characters-grid{grid-template-columns:1fr}.header-title,.page-header h2{font-size:1.5rem}}html,body,#root{width:100%;height:100%;overflow:hidden}.game-container{display:flex;flex-direction:column;flex:1 1 0%;min-height:0;width:100%;height:100vh}.game-layout{position:relative;display:grid;grid-template-columns:280px 1fr 320px;grid-template-rows:1fr;align-items:stretch;gap:20px;padding:0 20px;width:100%;max-width:none;margin:0;flex:1 1 0%;min-height:0;max-height:100%;align-content:stretch;height:100%}.game-sidebar{background:transparent;border:1px solid rgba(255,255,255,.04);border-radius:12px;padding:0;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-md);min-height:0;max-height:100%}.character-navbar{display:flex;gap:8px;padding:10px 12px;border-bottom:1px solid rgba(148,163,184,.1);background:#0f172a59;border-radius:8px}.char-nav-item{padding:6px 10px;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:#ffffffbf;cursor:pointer;transition:all .2s ease}.char-nav-item:hover{background:#ffffff14;color:#fffffff2}.char-nav-item.active{background:#3b82f61f;color:#60a5fa;border-color:#3b82f659;box-shadow:0 0 10px #3b82f640}.char-details{margin-top:10px;padding:10px 12px;border:1px solid rgba(148,163,184,.12);border-radius:8px;background:#02061759}.char-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.detail-item{display:flex;justify-content:space-between}.detail-label{font-size:10px;font-weight:600;color:#94a3b8cc;text-transform:uppercase;letter-spacing:.4px}.detail-value{font-size:12px;font-weight:700;color:#60a5fa;font-family:Monaco,monospace}.hp-section{display:flex;flex-direction:column;gap:8px}.hp-row{display:flex;justify-content:space-between;align-items:center}.hp-label{font-size:10px;font-weight:600;color:#94a3b8cc;text-transform:uppercase}.hp-value{font-size:12px;font-weight:700;color:#60a5fa;font-family:Monaco,monospace}.hp-bar{height:6px;background:#ffffff14;border-radius:4px;overflow:hidden}.hp-fill{height:100%;background:#3b82f6cc;box-shadow:0 0 10px #3b82f666}.ac-row,.level-row{display:flex;justify-content:space-between}.ac-label,.level-label{font-size:10px;font-weight:600;color:#94a3b8cc;text-transform:uppercase}.ac-value,.level-value{font-size:12px;font-weight:700;color:#60a5fa;font-family:Monaco,monospace}.sidebar-tabs-container{display:flex;gap:8px;padding:12px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.sidebar-tab-btn{flex:1;padding:8px 12px;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:#fff9;cursor:pointer;transition:all .3s ease}.sidebar-tab-btn:hover{background:#ffffff1a;color:#fffc}.sidebar-tab-btn.active{background:#3b82f61a;color:#60a5fa;border-color:#3b82f64d;box-shadow:0 0 12px #3b82f633}.abilities-container{display:flex;flex-direction:column;gap:10px;overflow-y:auto;flex:1;padding:12px;min-height:0}.basic-stats{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding-bottom:12px;border-bottom:1px solid rgba(148,163,184,.1)}.stat-block{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:6px 8px;background:#0003;border-left:2px solid rgba(59,130,246,.5);border-radius:4px;transition:all .18s ease}.stat-label{font-size:9px;font-weight:600;color:#94a3b8b3;text-transform:uppercase;letter-spacing:.3px;margin-bottom:2px}.stat-value{font-size:11px;font-weight:700;color:#60a5fa;font-family:Monaco,monospace}.ability-category{display:flex;flex-direction:column;gap:8px;padding:10px;background:transparent;border:1px solid rgba(255,255,255,.04);border-radius:8px;transition:all .18s ease}.ability-category:hover{border-color:#ffffff14}.ability-category-header{display:flex;align-items:center;gap:8px;padding:6px 8px;background:transparent;border-radius:6px}.category-icon{font-size:16px;flex-shrink:0;background:#0003;width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center}.category-title{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:#ec4899;margin:0}.ability-skills{display:flex;flex-direction:column;gap:6px}.ability-skill{display:flex;align-items:flex-start;gap:8px;padding:6px;background:transparent;border-radius:4px;transition:all .12s ease;position:relative}.ability-skill:hover{background:#ffffff05}.skill-modifier-badge{width:28px;height:28px;min-width:28px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;cursor:default;transition:all .2s ease;position:relative}.skill-modifier-badge[data-type=positive],.skill-modifier-badge[data-type=negative]{background:#ffffff08;border:1px solid rgba(209,209,209,.06);color:var(--sky-text);box-shadow:inset 0 0 6px #d1d1d105}.skill-modifier-badge[data-type=neutral]{background:#ffffff05;border:1px solid rgba(209,209,209,.04);color:var(--sky-text);box-shadow:inset 0 0 6px #d1d1d103}.skill-content{flex:1;min-width:0}.skill-name{display:block;font-size:11px;color:#ffffffe6;font-weight:500;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.skill-progress{display:flex;align-items:center;gap:6px}.progress-bar{flex:1;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:var(--sky-accent-bg, rgba(255,255,255,.06));border-radius:2px;transition:width .3s ease;box-shadow:0 0 8px #d1d1d10f}.progress-text{font-size:9px;color:#ffffff80;font-family:Monaco,monospace;white-space:nowrap;width:32px;text-align:right}.skill-bonus-ring{position:absolute;width:32px;height:32px;border:2px solid rgba(209,209,209,.12);border-radius:6px;pointer-events:none;top:2px;left:-2px;animation:bonus-pulse 2s infinite}@keyframes bonus-pulse{0%,to{box-shadow:0 0 #d1d1d10a}50%{box-shadow:0 0 0 4px #d1d1d105}}.stat-block:hover{background:#ffffff08;border-left-color:#d1d1d11f;transform:translate(2px)}.stat-label{font-size:10px;font-weight:600;color:#94a3b8cc;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:12px;font-weight:700;color:#60a5fa;font-family:Monaco,monospace}.spellbook-container{margin-top:24px;border-top:1px solid rgba(148,163,184,.2);padding:20px}.spellbook-container-full{display:flex;flex-direction:column;gap:12px;overflow-y:auto;flex:1;padding:20px}.spellbook-header{margin-bottom:16px}.spellbook-title{font-size:13px;font-weight:700;color:#ec4899;text-transform:uppercase;letter-spacing:1.5px;padding:8px 12px;background:#ec48991a;border:1px solid rgba(236,72,153,.4);border-radius:6px}.spellbook-tabs{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;background:#0000004d;padding:12px;border-radius:8px;border:1px solid rgba(148,163,184,.1)}.spell-tab{width:32px;height:32px;margin:0 auto;border-radius:50%;border:2px solid rgba(148,163,184,.3);background:#0003;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:16px}.spell-tab:hover:not(:disabled){transform:scale(1.1);box-shadow:0 0 12px #3b82f64d}.spell-tab.disabled{opacity:.5;cursor:not-allowed}.game-actions-wrapper{display:flex;flex-direction:column;gap:12px}.player-input{width:100%}.textarea-input{width:100%;background:#0f172aa6;color:#fffffff2;border:1px solid rgba(148,163,184,.06);padding:10px 12px;border-radius:8px;resize:vertical;font-size:14px;line-height:1.4;font-family:inherit;box-shadow:inset 0 1px #ffffff05}.textarea-input::-moz-placeholder{color:#ffffff59}.textarea-input::placeholder{color:#ffffff59}.textarea-input:disabled{opacity:.6;cursor:not-allowed}.player-input .btn-send,.player-input .btn-end{padding:8px 14px;border-radius:8px;font-weight:700;font-size:13px;cursor:pointer;border:none}.player-input .btn-send{background:#ffffff0f;color:var(--sky-text);box-shadow:0 6px 14px #d1d1d10f}.player-input .btn-send:disabled{opacity:.5;cursor:not-allowed}.player-input .btn-end{background:transparent;color:#ffffffe6;border:1px solid rgba(255,255,255,.04)}.player-input .btn-end:hover{border-color:#ffffff14}@media(max-width:900px){.game-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr auto;padding:12px;gap:12px}.game-sidebar{order:0}}.chat-thread{display:flex;flex-direction:column;gap:10px;max-height:60vh;overflow-y:auto;padding:8px 4px}.chat-message{display:flex;width:100%}.chat-message.player{justify-content:flex-end}.chat-message.dm{justify-content:flex-start}.chat-message.narration{justify-content:center}.chat-message.dialogue{justify-content:flex-start}.chat-message.dm_response{justify-content:center}.chat-bubble{max-width:80%;padding:10px 14px;border-radius:12px;font-size:14px;line-height:1.4}.chat-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;margin-right:8px;flex-shrink:0}.chat-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.chat-message.player .chat-avatar{margin-left:8px;margin-right:0}.chat-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.chat-sender-name{font-size:12px;font-weight:700;color:#ffffffd9}.chat-message.player .chat-bubble{background:#ffffff0a;color:var(--sky-text);border-bottom-right-radius:4px}.chat-message.dm .chat-bubble{background:#0f172aa6;color:#fffffff2;border-bottom-left-radius:4px;border:1px solid rgba(255,255,255,.04)}.chat-message.narration .chat-bubble{background:#ffffff08;color:var(--sky-text);border:1px solid rgba(209,209,209,.08);text-align:center;font-style:italic;max-width:90%;border-radius:12px}.chat-message.dialogue .chat-bubble{background:#22c55e1f;color:#fffffff2;border:1px solid rgba(34,197,94,.25);border-bottom-left-radius:4px;max-width:75%}.chat-message.dm_response .chat-bubble{background:#fbbf241f;color:#fffffff2;border:1px solid rgba(251,191,36,.3);text-align:center;max-width:85%;border-radius:12px}.chat-bubble .sender{display:block;font-size:11px;font-weight:700;color:#ffffffbf;margin-bottom:6px}.player-select,.input-add-player{background:#0f172a99;color:#fffffff2;border:1px solid rgba(255,255,255,.04);padding:6px 8px;border-radius:6px}.btn-add-player{padding:6px 10px;border-radius:6px;background:#3b82f6e6;color:#fff;font-weight:700;border:none}.chat-thread::-webkit-scrollbar{height:8px;width:8px}.chat-thread::-webkit-scrollbar-thumb{background:#ffffff0f;border-radius:8px}.spell-tab.active{border-color:#60a5fa;background:#3b82f633;box-shadow:0 0 12px #3b82f666;transform:scale(1.1)}.spells-list{display:flex;flex-direction:column;gap:12px;max-height:200px;overflow-y:auto}.spell-item{background:#ffffff05;border:1px solid rgba(209,209,209,.06);border-left:3px solid rgba(209,209,209,.08);border-radius:6px;padding:12px;display:flex;justify-content:space-between;align-items:center;transition:all .3s ease;cursor:pointer}.spell-item:hover{background:#ffffff08;border-color:#d1d1d11f;transform:translate(2px)}.spell-info{flex:1}.spell-name{font-size:12px;font-weight:600;color:#fff;margin:0 0 4px;cursor:pointer}.spell-name:hover{font-weight:700}.spell-meta{font-size:10px;color:#94a3b8;text-transform:uppercase;letter-spacing:.3px;display:flex;gap:8px}.spell-level{display:inline-block}.spell-damage{display:inline-block;font-family:Courier New,monospace}.spell-level-badge{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:#22c55e33;color:#86efac;font-size:11px;font-weight:700;border:1px solid rgba(34,197,94,.4);flex-shrink:0}.inventory-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#0f172a99;border-left:3px solid #8b5cf6;border-radius:6px;cursor:pointer;transition:all .3s ease}.inventory-item:hover{background:#8b5cf626;border-left-color:#a78bfa;transform:translate(2px)}.item-icon{font-size:16px;width:20px}.item-name{font-size:12px;color:#cbd5e1;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.game-main{display:flex;flex-direction:column;min-height:0}.narrative-container{background:var(--sky-bg);border:1px solid rgba(209,209,209,.06);border-radius:12px;padding:30px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;gap:20px;flex:1;box-shadow:0 8px 24px #0006}.narrative-header{padding-bottom:15px;border-bottom:2px solid rgba(59,130,246,.4)}.narrative-header h2{font-size:20px;font-weight:700;color:#60a5fa;margin:0;text-transform:uppercase;letter-spacing:1px}.narrative-content{flex:1;min-height:150px;overflow-y:auto;padding:15px 0}.narrative-text{font-size:14px;line-height:1.7;color:#cbd5e1;margin:0;text-align:justify}.actions-container{display:flex;flex-direction:column;gap:12px;margin-top:auto;padding-top:20px;border-top:1px solid rgba(148,163,184,.2)}.action-btn{padding:12px 20px;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;position:relative;overflow:hidden}@media(max-width:1200px){.game-layout{grid-template-columns:250px 1fr 280px;gap:15px;padding:15px}.narrative-container{padding:20px}.narrative-text{font-size:13px}}@media(max-width:768px){.game-layout{grid-template-columns:1fr;gap:15px;padding:10px;height:auto}.game-sidebar{max-height:250px}.sidebar-left{order:1}.game-main{order:2}.sidebar-right{order:3}.narrative-container{padding:15px}.narrative-header h2{font-size:16px}.narrative-text{font-size:12px}.actions-grid{grid-template-columns:1fr}}@media(max-width:480px){.game-layout{padding:8px}.game-sidebar{padding:12px}.narrative-container{padding:12px;gap:15px}.action-btn{padding:10px 15px;font-size:11px}.stat-label{font-size:9px}.stat-value{font-size:11px}}.game-sidebar{background:var(--sky-bg);border:1px solid rgba(209,209,209,.06);border-radius:12px;padding:20px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow-y:auto}.sidebar-header{margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid rgba(59,130,246,.3)}.sidebar-header h3{font-size:16px;font-weight:600;color:#60a5fa;margin:0;text-transform:uppercase;letter-spacing:1px}.character-stats{display:flex;flex-direction:column;gap:12px}.stat-block{display:flex;justify-content:space-between;align-items:center;padding:10px;background:#0f172a80;border-left:3px solid #3b82f6;border-radius:6px;transition:all .3s ease}.stat-block:hover{background:#3b82f61a;border-left-color:#60a5fa}.stat-label{font-size:12px;color:#94a3b8;text-transform:uppercase;font-weight:600}.stat-value{font-size:14px;font-weight:700;color:#60a5fa}.inventory-list{display:flex;flex-direction:column;gap:10px}.inventory-item{display:flex;align-items:center;gap:10px;padding:10px;background:#0f172a80;border-left:3px solid #8b5cf6;border-radius:6px;cursor:pointer;transition:all .3s ease}.inventory-item:hover{background:#8b5cf61a;border-left-color:#a78bfa}.item-icon{font-size:18px;width:24px}.item-name{font-size:13px;color:#cbd5e1;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.game-main{display:flex;flex-direction:column}.narrative-container{background:var(--sky-bg);border:1px solid rgba(209,209,209,.06);border-radius:12px;padding:30px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;gap:20px;flex:1}.narrative-header{padding-bottom:15px;border-bottom:2px solid rgba(59,130,246,.3)}.narrative-header h2{font-size:24px;font-weight:700;color:#60a5fa;margin:0;text-transform:uppercase;letter-spacing:1px}.narrative-content{flex:1;min-height:200px;max-height:100%;overflow-y:auto;padding:15px 0}.narrative-text{font-size:15px;line-height:1.8;color:#cbd5e1;margin:0;text-align:justify;font-style:italic}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:15px;min-height:200px}.spinner{width:50px;height:50px;border:3px solid rgba(59,130,246,.2);border-top:3px solid #60a5fa;border-radius:50%;animation:spin 1s linear infinite}.actions-container{display:flex;flex-direction:column;gap:12px;margin-top:auto;padding-top:20px;border-top:1px solid rgba(148,163,184,.1)}.actions-grid{display:grid;grid-template-columns:1fr;gap:12px}.action-btn{padding:12px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;position:relative;overflow:hidden}.action-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:#ffffff0f;transition:left .5s ease}.action-btn:hover:before{left:100%}.action-btn-primary{background:#ffffff0a;color:var(--sky-text);box-shadow:0 0 10px #d1d1d10f}.action-btn-primary:hover:not(:disabled){background:#ffffff0f;box-shadow:0 0 14px #d1d1d114;transform:translateY(-2px)}.action-btn-secondary{background:#ffffff08;color:var(--sky-text);border:1px solid rgba(209,209,209,.06)}.action-btn-secondary:hover:not(:disabled){background:#ffffff0d;box-shadow:0 0 10px #d1d1d10f;transform:translateY(-2px);border-color:#d1d1d11f}.action-btn:disabled{opacity:.5;cursor:not-allowed}.game-sidebar::-webkit-scrollbar,.narrative-content::-webkit-scrollbar{width:6px}.game-sidebar::-webkit-scrollbar-track,.narrative-content::-webkit-scrollbar-track{background:#0f172a80;border-radius:3px}.game-sidebar::-webkit-scrollbar-thumb,.narrative-content::-webkit-scrollbar-thumb{background:#3b82f666;border-radius:3px}.game-sidebar::-webkit-scrollbar-thumb:hover,.narrative-content::-webkit-scrollbar-thumb:hover{background:#3b82f699}@media(max-width:1200px){.game-layout{grid-template-columns:250px 1fr 280px;gap:15px;padding:15px}.narrative-container{padding:20px}.narrative-text{font-size:14px}}@media(max-width:768px){.game-layout{grid-template-columns:1fr;gap:15px;padding:10px}.game-sidebar{max-height:300px}.sidebar-left{order:1}.game-main{order:2}.sidebar-right{order:3}.narrative-container{padding:15px}.narrative-header h2{font-size:18px}.narrative-text{font-size:13px}.actions-grid{grid-template-columns:1fr}}@media(max-width:480px){.game-layout{padding:8px}.game-sidebar{padding:12px}.narrative-container{padding:12px;gap:15px}.action-btn{padding:10px 15px;font-size:12px}.stat-label{font-size:10px}.stat-value{font-size:12px}}.connected-players{padding:16px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.players-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#ffffff80;margin-bottom:12px}.players-list{display:flex;flex-direction:column;gap:8px}.player-item{display:flex;align-items:center;gap:10px;padding:8px;background:#ffffff08;border-radius:8px;transition:background .2s ease}.player-item:hover{background:#ffffff0d}.player-avatar{width:32px;height:32px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid rgba(255,255,255,.1)}.player-avatar-placeholder{width:32px;height:32px;border-radius:50%;background:#ffffff0a;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:#fff;border:2px solid rgba(255,255,255,.1)}.player-name{flex:1;font-size:13px;font-weight:500;color:#ffffffe6}.player-status{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 8px currentColor}.player-status.online{background:#10b981;color:#10b981}.player-status.offline{background:#f59e0b;color:#f59e0b}.quest-tabs-container{display:flex;gap:8px;padding:12px;border-bottom:1px solid rgba(255,255,255,.1)}.quest-tab-btn{flex:1;padding:8px 12px;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:#fff9;cursor:pointer;transition:all .3s ease}.quest-tab-btn:hover{background:#ffffff1a;color:#fffc}.quest-tab-btn.active{background:#ec48991a;color:#ec4899;border-color:#ec48994d;box-shadow:0 0 12px #ec489933}.quest-content{padding:0;overflow-y:auto;height:calc(100% - 50px)}.quest-content::-webkit-scrollbar{width:6px}.quest-content::-webkit-scrollbar-track{background:#0f172a80}.quest-content::-webkit-scrollbar-thumb{background:#ec48994d;border-radius:3px}.quest-content::-webkit-scrollbar-thumb:hover{background:#ec489980}.quest-section{padding:12px;border-top:1px solid rgba(255,255,255,.05)}.quest-section:first-child{border-top:none}.quest-section-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#ec48990d;border:1px solid rgba(236,72,153,.2);border-radius:6px;margin-bottom:12px}.quest-section-header h3{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#ec4899;margin:0}.quest-section-header.completed{background:#6b72800d;border-color:#6b728033}.quest-section-header.completed h3{color:#6b7280}.quest-empty-text{font-size:11px;color:#fff6;font-style:italic;padding:12px;text-align:center;margin:0}.rumors-list{display:flex;flex-direction:column;gap:12px}.rumor-card{border:1px solid rgba(236,72,153,.2);border-radius:6px;padding:12px;background:#ec48990d;transition:all .3s ease}.rumor-card:hover{border-color:#ec489966;background:#ec48991a}.rumor-title{font-size:12px;font-weight:600;color:#fff;margin:0 0 8px;line-height:1.3}.rumor-meta{display:flex;gap:8px;margin-bottom:8px;font-size:10px}.rumor-level{padding:3px 8px;background:#9333ea33;border:1px solid rgba(147,51,234,.3);color:#c4b5fd;border-radius:3px;font-weight:600}.rumor-xp{padding:3px 8px;background:#3b82f633;border:1px solid rgba(59,130,246,.3);color:#93c5fd;border-radius:3px;font-weight:600}.rumor-description{font-size:11px;color:#ffffffb3;margin:0 0 8px;line-height:1.4;font-style:italic}.rumor-source{font-size:10px;color:#ffffff80;padding:6px 8px;background:#ffffff0d;border-radius:4px;border-left:2px solid rgba(236,72,153,.3)}.completed-quest{display:flex;align-items:flex-start;gap:8px;padding:8px 12px;background:#6b72800d;border:1px solid rgba(107,114,128,.2);border-radius:4px;opacity:.7}.checkmark-icon{width:16px;height:16px;color:#22c55e;flex-shrink:0;margin-top:2px}.completed-quest-title{font-size:11px;font-weight:500;color:#fffc;margin:0;text-decoration:line-through;line-height:1.3}.inventory-section{padding:12px;border-top:1px solid rgba(255,255,255,.1);margin-top:auto}.inventory-section .sidebar-header{margin-bottom:12px}.inventory-list{display:flex;flex-direction:column;gap:6px}.inventory-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#22c55e0d;border:1px solid rgba(34,197,94,.2);border-left:3px solid rgb(34,197,94);border-radius:4px;transition:all .2s ease}.inventory-item:hover{background:#22c55e1a;border-left-color:#84cc16;transform:translate(2px)}.item-icon{font-size:14px;flex-shrink:0}.item-name{font-size:11px;color:#ffffffe6;font-weight:500}:root{box-sizing:border-box}.game-container{display:flex;flex-direction:column;flex:1 1 0%;min-height:0;width:100%;color:var(--sky-text);background:var(--sky-bg);position:relative}.game-container:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 20% 80%,rgba(120,119,198,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,119,198,.1) 0%,transparent 50%),radial-gradient(circle at 40% 40%,rgba(120,219,226,.05) 0%,transparent 50%);pointer-events:none}.game-layout{display:grid;grid-template-columns:260px 1fr 300px;grid-template-rows:1fr;align-items:stretch;gap:var(--spacing-lg);padding:var(--spacing-lg);flex:1 1 0%;min-height:0;align-content:stretch;overflow:hidden;height:100%}.game-sidebar{background:transparent;border:1px solid rgba(255,255,255,.04);border-radius:var(--radius-xl);padding:var(--spacing-xl);display:flex;flex-direction:column;gap:var(--spacing-lg);min-height:0;overflow:auto;align-self:stretch;height:100%;position:relative;-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:var(--shadow-md);transition:transform .18s ease,box-shadow .18s ease}.game-main{display:flex;flex-direction:column;min-height:0;flex:1 1 0%;height:100%}.narrative-container{background:transparent;border:1px solid rgba(255,255,255,.04);border-radius:var(--radius-xl);display:flex;flex-direction:column;gap:var(--spacing-md);flex:1 1 0%;min-height:0;overflow:hidden;height:100%;padding:var(--spacing-xl);position:relative;-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:var(--shadow-md);transition:transform .18s ease,box-shadow .18s ease}.narrative-header{padding-bottom:12px;border-bottom:1px solid rgba(96,165,250,.06)}.narrative-header h2{margin:0;color:#7fb3ff;letter-spacing:.8px}.narrative-content{flex:1 1 0%;min-height:0;max-height:none!important;overflow:auto;padding-right:6px;height:100%}.narrative-text{color:#cfe7ff;line-height:1.6}.actions-container{padding-top:12px;border-top:1px solid rgba(255,255,255,.02)}.quest-content,.spells-list{min-height:0}@media(max-width:1024px){.game-layout{grid-template-columns:220px 1fr 260px;padding:12px;gap:12px}}@media(max-width:768px){.game-layout{grid-template-columns:1fr;padding:12px;gap:12px}.game-sidebar{max-height:260px;border-radius:12px}.game-sidebar:before{border-radius:14px}.narrative-container{border-radius:12px}.narrative-container:before{border-radius:14px}}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media(prefers-color-scheme:light){body{background:var(--darkest-bg)!important}}.quest-tab-btn{flex:1;padding:8px 10px;background:transparent;border:1px solid rgba(255,255,255,.04);color:#d1d1d1f2;border-radius:6px;cursor:pointer;font-size:11px;font-weight:600;transition:color .12s ease,transform .12s ease}.quest-tab-btn.active{background:var(--sky-accent-bg);border-color:#ffffff0f;color:var(--sky-accent-text)}.quest-tab-btn:hover{color:var(--sky-text)}.quest-content{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.quest-section{background:transparent;border-radius:8px;padding:10px;border-left:3px solid rgba(255,255,255,.06)}.quest-section-header{margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid rgba(139,92,246,.3)}.quest-section-header h3{font-size:13px;font-weight:600;color:#a78bfa;margin:0;text-transform:uppercase;letter-spacing:.5px}.quest-section-header.completed{border-bottom-color:#22c55e4d}.quest-section-header.completed h3{color:var(--success-green)}.rumor-card{background:transparent;border:1px solid rgba(255,255,255,.04);border-radius:6px;padding:8px;margin-bottom:8px;transition:all .18s ease}.rumor-card:hover{border-color:#ffffff14;background:#ffffff05}.rumor-title{font-weight:600;color:var(--secondary-blue);font-size:12px;margin:0 0 6px}.rumor-meta{display:flex;gap:8px;margin-bottom:6px;font-size:11px}.rumor-level{color:#cbd5e1;background:#3b82f633;padding:2px 6px;border-radius:3px}.rumor-xp{color:#86efac;background:#22c55e1a;padding:2px 6px;border-radius:3px}.rumor-description{font-size:11px;color:#cbd5e1;margin:6px 0;line-height:1.4}.rumor-source{font-size:10px;color:var(--border-color);margin-top:6px}.quest-empty-text{color:var(--border-color);font-size:12px;text-align:center;padding:20px 0}.completed-quests{display:flex;flex-direction:column;gap:8px}.completed-quest{display:flex;align-items:center;gap:8px;padding:8px;background:#22c55e1a;border-left:3px solid var(--success-green);border-radius:6px;font-size:12px}.checkmark-icon{width:16px;height:16px;color:var(--success-green);flex-shrink:0}.completed-quest-title{margin:0;color:var(--success-green);font-weight:500}.inventory-section{padding-top:12px;border-top:1px solid rgba(148,163,184,.1)}.game-sidebar::-webkit-scrollbar,.narrative-content::-webkit-scrollbar,.game-layout::-webkit-scrollbar,.quest-content::-webkit-scrollbar,.spells-list::-webkit-scrollbar{width:6px}.game-sidebar::-webkit-scrollbar-track,.narrative-content::-webkit-scrollbar-track,.game-layout::-webkit-scrollbar-track,.quest-content::-webkit-scrollbar-track,.spells-list::-webkit-scrollbar-track{background:#0f172a4d}.game-sidebar::-webkit-scrollbar-thumb,.narrative-content::-webkit-scrollbar-thumb,.game-layout::-webkit-scrollbar-thumb,.quest-content::-webkit-scrollbar-thumb,.spells-list::-webkit-scrollbar-thumb{background:#00d4ff80;border-radius:3px}.game-sidebar::-webkit-scrollbar-thumb:hover,.narrative-content::-webkit-scrollbar-thumb:hover,.game-layout::-webkit-scrollbar-thumb:hover,.quest-content::-webkit-scrollbar-thumb:hover,.spells-list::-webkit-scrollbar-thumb:hover{background:#00d4ffcc}@media(max-width:1024px){.game-layout{grid-template-columns:220px 1fr 260px;gap:10px;padding:10px}.narrative-container{padding:15px}.narrative-text{font-size:13px}}@media(max-width:768px){.game-layout{grid-template-columns:1fr}.game-sidebar{max-height:250px}}.story-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}@keyframes slideDown{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.story-modal{background:var(--sky-bg);border-radius:var(--radius-lg);border:1px solid var(--border-light);position:relative;width:90%;max-width:900px;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .28s ease;font-family:inherit;color:var(--sky-text);box-shadow:var(--shadow-xl),inset 0 1px #ffffff05;overflow:hidden;padding:0}.story-modal:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:#ffffff03;border-radius:8px;box-shadow:0 0 0 1px #ffffff05 inset;z-index:0}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@media(prefers-reduced-motion:reduce){.story-modal:before{animation:none!important}}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.story-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--border-medium);background:#ffffff03}.story-modal-header h2{margin:0;font-size:20px;font-weight:700;color:var(--sky-text);letter-spacing:.6px}.story-modal-close{background:none;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s}.story-modal-close:hover{background:#ef44441a;color:var(--error-red)}.story-modal-loading{padding:40px;text-align:center;color:var(--sky-text);font-size:16px}.story-modal-error{margin:16px 24px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:var(--error-red-light);font-size:14px}.story-modal-content{flex:1;overflow-y:auto;padding:var(--spacing-2xl)}.story-section{margin-bottom:32px}.story-section-title{font-size:18px;color:var(--sky-text);margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.04)}.story-intros-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px;margin-bottom:16px}.story-intro-card{background:transparent;border:1px solid rgba(209,209,209,.05);border-radius:6px;padding:14px;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease}.story-intro-card:hover{transform:translateY(-3px);box-shadow:0 8px 20px #0000008c}.story-intro-preview{font-size:13px;color:var(--text-secondary);line-height:1.5}.story-preview{margin-top:32px;padding:var(--spacing-xl);background:transparent;border:1px solid var(--border-medium);border-radius:var(--radius-lg)}.story-preview-sticky{margin:0 20px 20px;padding:18px;background:transparent;border:1px solid rgba(255,255,255,.04);border-radius:6px;min-height:140px;animation:slideDown .22s ease}.story-preview h3{font-size:16px;color:var(--sky-text);margin-bottom:12px}.story-preview-text{font-size:15px;color:var(--text-primary);line-height:1.8;white-space:pre-wrap}.story-modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-2xl);border-top:1px solid var(--border-medium)}.story-button{padding:12px 24px;border-radius:var(--radius-md);font-size:15px;font-weight:600;cursor:pointer;transition:all .12s ease;border:none;font-family:inherit}.story-button-cancel{background:transparent;color:var(--sky-text);border:1px solid rgba(255,255,255,.04)}.story-button-cancel:hover:not(:disabled){background:#ffffff0a;color:var(--sky-accent-text)}.story-button-start{background:var(--sky-accent-bg);border:1px solid rgba(255,255,255,.06);color:var(--sky-accent-text);padding:10px 18px;border-radius:6px;font-weight:700;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease;box-shadow:0 6px 18px #0009}.story-button-start:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 26px #000000b3}.story-button:disabled{opacity:.5;cursor:not-allowed}.char-creation-container{min-height:100vh;background:radial-gradient(1400px 900px at 10% 10%,rgba(59,130,246,.08),transparent),radial-gradient(900px 700px at 90% 20%,rgba(236,72,153,.07),transparent),#0b0f1a;display:flex;align-items:center;justify-content:center;padding:20px;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;position:relative;z-index:1;pointer-events:auto}.char-creation-card{background:linear-gradient(145deg,#0e1523eb,#121a2ce6);border:1px solid rgba(148,163,184,.18);border-radius:16px;padding:40px;max-width:700px;width:100%;position:relative;z-index:2;pointer-events:auto;max-height:90vh;overflow-y:auto;overflow-x:hidden;box-shadow:0 15px 45px #0006,0 0 0 1px #3b82f614;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.char-creation-card h1{color:#f8fafc;font-size:2.2rem;margin-bottom:24px;margin-top:0;text-align:center;font-weight:700;letter-spacing:.5px}.char-creation-card h2{color:#e5e7eb;font-size:1.5rem;margin-bottom:20px;text-transform:uppercase;letter-spacing:.8px;font-weight:600}.creation-step{animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.form-group{margin-bottom:20px}.form-group label{display:block;color:#cbd5e1;font-weight:600;margin-bottom:10px;font-size:.95rem;letter-spacing:.2px}.form-group input[type=text],.form-group input[type=number],.form-group select,.form-group textarea{width:100%;padding:12px 15px;background:#0f172aa6;border:1px solid rgba(148,163,184,.2);border-radius:8px;color:#e5e7eb;font-size:.95rem;transition:all .2s ease;font-family:inherit}.form-group input[type=text]:focus,.form-group input[type=number]:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#60a5fab3;box-shadow:0 0 0 3px #3b82f633;background:#0f172acc}.form-group textarea{resize:vertical;min-height:100px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media(max-width:600px){.form-row{grid-template-columns:1fr}}.class-description{background:#ffffff05;border-left:4px solid rgba(209,209,209,.06);padding:15px;border-radius:6px;margin:20px 0}.class-desc-text{color:#cbd5e1;font-size:.95rem;line-height:1.7;margin:0}.ability-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:15px;margin:20px 0}.ability-box{background:#ffffff05;border:1px solid rgba(209,209,209,.04);border-radius:8px;padding:15px;text-align:center;transition:all .3s ease}.ability-box:hover{border-color:#ffffff14;box-shadow:0 6px 16px #0009}.ability-name{color:#cbd5e1;font-weight:700;font-size:.9rem;margin-bottom:8px;letter-spacing:.3px}.ability-score{color:#60a5fa;font-size:1.8rem;font-weight:700;margin-bottom:5px;font-family:Monaco,Courier New,monospace}.ability-mod{color:#86efac;font-size:.95rem;font-weight:600;margin-bottom:8px}.ability-select,.ability-input{width:100%;padding:6px;background:#ffffff05;border:1px solid rgba(209,209,209,.04);border-radius:4px;color:var(--sky-text);font-size:.85rem}.ability-select:focus,.ability-input:focus{outline:none;border-color:#ffffff1f}.method-toggle{background:#ffffff05;padding:15px;border-radius:6px;margin-bottom:20px;display:flex;gap:20px}.method-toggle label{display:flex;align-items:center;color:var(--sky-text);cursor:pointer;margin:0}.method-toggle input[type=radio]{margin-right:8px;cursor:pointer}.standard-array,.manual-attributes{background:#ffffff05;padding:20px;border-radius:6px;margin-bottom:20px}.standard-array>p,.manual-attributes>p{color:var(--sky-text);margin-bottom:15px}.character-review{background:#ffffff05;border:1px solid rgba(209,209,209,.04);border-radius:6px;padding:20px;margin-bottom:20px}.review-item{color:var(--sky-text);padding:8px 0;border-bottom:1px solid rgba(209,209,209,.04)}.review-item strong{color:var(--sky-text);font-weight:700;margin-right:10px}.review-item:last-child{border-bottom:none}.review-abilities{margin-top:15px;padding-top:15px;border-top:1px solid rgba(209,209,209,.04)}.review-abilities strong{color:var(--sky-text);display:block;margin-bottom:10px}.review-ability strong{color:var(--sky-text);margin:0;display:inline}.error-message{background:#f871711f;border:1px solid rgba(248,113,113,.3);color:#fecdd3;padding:14px 18px;border-radius:10px;margin-bottom:20px;font-size:.95rem;font-weight:500;animation:shake .5s ease-in-out;box-shadow:0 2px 8px #f8717126}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.button-group{display:flex;gap:15px;margin-top:30px;justify-content:center}@media(max-width:600px){.button-group{flex-direction:column}}.btn-prev,.btn-next,.btn-create{flex:1;padding:12px 20px;border:1px solid rgba(209,209,209,.06);border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;background:transparent;color:var(--sky-text)}.btn-prev{background:transparent;color:var(--sky-text)}.btn-prev:hover:not(:disabled){background:#ffffff0a;transform:translate(-3px)}.btn-next{background:transparent;color:var(--sky-text);border-color:#d1d1d10f}.btn-next:hover:not(:disabled){background:#ffffff0a;transform:translate(3px)}.btn-next:disabled{opacity:.5;cursor:not-allowed}.btn-create{background:linear-gradient(135deg,#fbbf24,#f97316);color:#0b1224;border:none;min-width:200px;box-shadow:0 6px 20px #f973164d,inset 0 1px #ffffff40}.btn-create:hover:not(:disabled){box-shadow:0 10px 28px #f9731666,inset 0 1px #ffffff4d;transform:translateY(-2px)}.btn-create:disabled{opacity:.6;cursor:not-allowed}.avatar-description{text-align:center;color:var(--sky-text);margin-bottom:30px;font-size:1rem;line-height:1.6}.avatar-generation{display:flex;flex-direction:column;align-items:center;gap:30px;margin-bottom:30px}.avatar-placeholder{width:100%;max-width:400px;height:400px;background:#ffffff05;border:2px dashed rgba(209,209,209,.06);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--sky-text)}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:20px;text-align:center}.spinner{width:60px;height:60px;border:4px solid rgba(255,255,255,.06);border-top:4px solid rgba(255,255,255,.18);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-spinner p{color:var(--sky-text);margin:0}.loading-subtitle{color:var(--text-secondary);font-size:.9rem!important}.avatar-empty{text-align:center;color:var(--sky-text);display:flex;flex-direction:column;gap:10px}.avatar-empty p{margin:0}.small-text{color:var(--text-secondary);font-size:.9rem}.btn-generate-avatar{padding:14px 32px;background:#ffffff0f;color:var(--sky-text);border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.btn-generate-avatar:hover:not(:disabled){box-shadow:0 6px 16px #0009;transform:translateY(-2px)}.btn-generate-avatar:disabled{opacity:.6;cursor:not-allowed}.avatar-display{display:flex;flex-direction:column;align-items:center;gap:20px;margin-bottom:30px}.avatar-image-container{width:100%;max-width:400px;border:1px solid rgba(209,209,209,.06);border-radius:12px;overflow:hidden}.avatar-image{width:100%;height:auto;display:block}.btn-skip{flex:1;padding:12px 20px;border:1px solid rgba(209,209,209,.06);border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;background:transparent;color:#d1d1d1d9}.btn-skip:hover:not(:disabled){background:#ffffff08}.btn-skip:disabled{opacity:.5;cursor:not-allowed}.appearance-form{background:#ffffff05;padding:20px;border-radius:8px;border:1px solid rgba(209,209,209,.04);margin-bottom:20px}.photo-upload{background:#ffffff05;padding:20px;border-radius:8px;border:2px dashed rgba(209,209,209,.06);text-align:center}.photo-upload input[type=file]{margin:15px 0}.photo-preview{margin-top:15px;border-radius:8px;overflow:hidden;max-width:200px;margin-left:auto;margin-right:auto}.photo-preview img{width:100%;height:auto;border:1px solid rgba(209,209,209,.06);border-radius:8px}.form-group input[type=checkbox]{margin-right:8px;cursor:pointer}.form-group label:has(input[type=checkbox]){display:flex;align-items:center;cursor:pointer;margin-bottom:10px}.form-group label:not(:has(input[type=checkbox])){display:block;color:var(--sky-text);font-weight:600;margin-bottom:8px;font-size:.95rem}.form-group label input[type=checkbox]{width:18px;height:18px}.form-group textarea{margin-top:10px;margin-bottom:15px}@media(max-width:600px){.char-creation-card{padding:25px}.char-creation-card h1{font-size:1.8rem}.char-creation-card h2{font-size:1.3rem}.ability-grid{grid-template-columns:repeat(2,1fr)}.avatar-placeholder{height:300px}}.char-creation-card::-webkit-scrollbar{width:8px}.char-creation-card::-webkit-scrollbar-track{background:#0f172a80;border-radius:3px}.char-creation-card::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:4px}.char-creation-card::-webkit-scrollbar-thumb:hover{background:#ffffff38}.avatar-info{background:#ffffff05;padding:20px;border-radius:8px;width:100%;max-width:400px;border-left:4px solid rgba(209,209,209,.06)}.avatar-info p{margin:10px 0;color:var(--sky-text)}.avatar-success{color:var(--sky-text);text-align:center;font-size:1.1rem;font-weight:600}.btn-upload-avatar{padding:14px 32px;background:#ffffff0f;color:var(--sky-text);border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.btn-upload-avatar:hover{box-shadow:0 10px 30px #f5576c66;transform:translateY(-2px)}.avatar-option-divider{color:var(--text-secondary);font-weight:600;font-size:.9rem}.settings-container{min-height:100vh;background:radial-gradient(1400px 900px at 10% 10%,rgba(59,130,246,.08),transparent),radial-gradient(900px 700px at 90% 20%,rgba(236,72,153,.07),transparent),#0b0f1a;padding:2rem;display:flex;justify-content:center;align-items:flex-start;overflow-y:auto}.settings-content{width:100%;max-width:1200px;background:linear-gradient(145deg,#0e1523eb,#121a2ce6);border:1px solid rgba(148,163,184,.18);border-radius:16px;padding:2rem;box-shadow:0 15px 45px #0006,0 0 0 1px #3b82f614;margin-bottom:2rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.settings-content h1{font-size:2.5rem;margin-bottom:2rem;text-align:center;font-weight:700;color:#f8fafc;letter-spacing:.5px}.settings-section{margin-bottom:3rem;padding-bottom:2rem;border-bottom:2px solid rgba(102,126,234,.2)}.settings-section:last-of-type{border-bottom:none;padding-bottom:0}.settings-card-glow{border:1px solid rgba(168,85,247,.3);box-shadow:0 0 20px #a855f71a}.settings-content .card-magic-replace{background:var(--sky-bg);border:2px solid rgba(209,209,209,.06);border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 32px #0000004d,0 0 0 1px #a855f71a;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.settings-section h2{font-size:1.75rem;color:#e5e7eb;margin-bottom:1.5rem;font-weight:600;letter-spacing:.3px}.section-description{color:#cbd5e1d9;margin-bottom:1.5rem;font-size:.95rem;line-height:1.6}.user-info-card{background:#667eea1a;border-radius:12px;padding:1.5rem;border:1px solid rgba(102,126,234,.3)}.info-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.1)}.info-row:last-child{border-bottom:none}.info-label{font-weight:600;color:#cbd5e1cc;font-size:.95rem}.info-value{color:#e5e7eb;font-weight:500;font-size:.95rem}.admin-badge{background:transparent;color:var(--sky-text);font-weight:700}.admin-section{background:#ffd7000d;border-radius:12px;padding:1.5rem;margin-bottom:2rem;border:1px solid rgba(255,215,0,.2)}.users-table-container{overflow-x:auto;margin-bottom:2rem;border-radius:8px;box-shadow:0 2px 8px #0000004d}.users-table{width:100%;border-collapse:collapse;background:#1e1e32cc}.users-table thead{background:#ffffff05;color:var(--sky-text)}.users-table th{padding:1rem;text-align:left;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;color:#f8fafc}.users-table td{padding:1rem;border-bottom:1px solid rgba(148,163,184,.15);color:#e5e7eb;font-size:.9rem}.users-table tbody tr{transition:background-color .2s}.users-table tbody tr:hover{background-color:#667eea26}.admin-row{background-color:#ffd70014}.you-badge{margin-left:.5rem;padding:.25rem .5rem;background:var(--primary-purple);color:#fff;border-radius:4px;font-size:.75rem;font-weight:600}.badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600;display:inline-block}.badge-admin{background:#ffffff0a;color:var(--sky-text)}.badge-user{background:#ffffff26;color:var(--text-secondary)}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.btn-action{padding:.5rem 1rem;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.85rem}.btn-primary{background:linear-gradient(135deg,#fbbf24,#f97316);color:#0b1224;border:none;padding:12px 24px;border-radius:10px;font-weight:700;font-size:.95rem;box-shadow:0 6px 20px #f973164d,inset 0 1px #ffffff40}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 28px #f9731666,inset 0 1px #ffffff4d}.btn-warning{background:#ffffff0a;color:var(--sky-text)}.btn-warning:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f39c1299}.btn-danger{background:#ffffff0a;color:var(--sky-text)}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 4px 12px #e74c3c99}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-top:2rem}.stat-card{background:#1e1e3299;border-radius:12px;padding:1.5rem;text-align:center;box-shadow:0 2px 8px #0000004d;border:2px solid rgba(102,126,234,.2);transition:all .3s}.stat-card:hover{border-color:#d1d1d11f;transform:translateY(-4px);box-shadow:0 8px 20px #00000059;background:#ffffff05;border-radius:12px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:all .3s ease}.stat-value{font-size:2.5rem;font-weight:700;color:var(--sky-text);margin-bottom:.5rem}.stat-label{font-size:.9rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.back-button-container{margin-top:2rem;text-align:center}.btn-back{padding:.75rem 2rem;background:#ffffff0f;color:var(--sky-text);border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s;font-size:1rem}.btn-back:hover{transform:translateY(-2px);box-shadow:0 8px 16px #667eea80}.loading,.error-message{text-align:center;padding:2rem;font-size:1.2rem;color:var(--sky-text)}.error-message{background:#e74c3c26;border:2px solid var(--error-red);border-radius:8px;color:var(--error-red-light);margin-bottom:1.5rem}@media(max-width:768px){.settings-content{padding:1rem}.settings-content h1{font-size:2rem}.users-table{font-size:.85rem}.users-table th,.users-table td{padding:.5rem}.action-buttons{flex-direction:column}.btn-action{width:100%}.stats-cards{grid-template-columns:1fr}}.settings-tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid rgba(102,126,234,.2);flex-wrap:wrap}.settings-tab{padding:.75rem 1.5rem;background:transparent;border:none;border-bottom:3px solid transparent;color:#cbd5e1d9;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.95rem;border-radius:6px 6px 0 0}.settings-tab:hover{color:#60a5fa;background:#3b82f61a}.settings-tab.active{color:#60a5fa;border-bottom-color:#60a5fa;background:#3b82f626}.tab-content{min-height:300px}.form-input,.form-select,.form-textarea{width:100%;padding:12px 15px;background:#0f172aa6;border:1px solid rgba(148,163,184,.2);border-radius:8px;font-size:.95rem;color:#e5e7eb;transition:all .2s ease}.form-input::-moz-placeholder{color:#94a3b899}.form-input::placeholder{color:#94a3b899}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#60a5fab3;box-shadow:0 0 0 3px #3b82f633;background:#0f172acc}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-primary);font-weight:600}.password-form{display:flex;flex-direction:column;gap:1rem;max-width:400px}.appearance-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.appearance-option label{display:block;margin-bottom:.5rem;color:var(--text-primary);font-weight:600}.color-picker{width:100%;height:50px;background:#1e1e3299;border:2px solid rgba(102,126,234,.3);border-radius:8px;cursor:pointer}.css-editor{width:100%;padding:1rem;background:#1e1e3299;border:2px solid rgba(102,126,234,.3);border-radius:8px;font-family:Courier New,monospace;font-size:.9rem;color:var(--text-primary);resize:vertical}.config-grid{display:grid;gap:2rem;margin-bottom:2rem}.config-section{padding:1.5rem;background:#667eea1a;border-radius:12px;border:2px solid rgba(102,126,234,.2)}.config-section h3{color:var(--primary-purple);margin-bottom:1rem;font-size:1.25rem}.placeholder-content{padding:2rem;background:#667eea14;border-radius:12px;border:2px dashed var(--primary-purple);text-align:center}.placeholder-content p{font-size:1.25rem;color:var(--primary-purple);font-weight:600;margin-bottom:1rem}.placeholder-content ul{list-style:none;padding:0;color:var(--text-secondary)}.placeholder-content li{padding:.5rem 0;font-size:1rem}.placeholder-content li:before{content:"✓ ";color:var(--primary-purple);font-weight:700;margin-right:.5rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s}.modal-content{background:#1a1a2efa;border:1px solid rgba(102,126,234,.3);border-radius:16px;padding:2rem;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 10px 40px #00000080;animation:slideUp .3s;border:1px solid rgba(168,85,247,.3);box-shadow:0 0 20px #a855f71a}.modal-content h2{color:var(--primary-purple);margin-bottom:1.5rem}.campaign-details{color:var(--text-primary)}.detail-row{padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.1);color:var(--text-primary)}.detail-row strong{color:var(--primary-purple);display:inline-block;min-width:150px}.participants-list{list-style:none;padding:0;margin-top:1rem}.participants-list li{padding:.5rem;background:#667eea1a;margin-bottom:.5rem;border-radius:6px;border-left:3px solid var(--primary-purple);color:var(--text-primary)}.participants-list em{color:var(--text-secondary);font-size:.9rem}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{top:0;right:0;bottom:0;left:0}.z-50{z-index:50}.mb-2{margin-bottom:.5rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.block{display:block}.flex{display:flex}.table{display:table}.h-3{height:.75rem}.h-5{height:1.25rem}.h-7{height:1.75rem}.min-h-screen{min-height:100vh}.w-3{width:.75rem}.w-5{width:1.25rem}.w-7{width:1.75rem}.w-full{width:100%}.flex-1{flex:1 1 0%}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:.5rem}.overflow-auto{overflow:auto}.rounded-full{border-radius:9999px}.border{border-width:1px}.border-blue-400\/40{border-color:#60a5fa66}.border-t-blue-500{--tw-border-opacity: 1;border-top-color:rgb(59 130 246 / var(--tw-border-opacity, 1))}.bg-black{--tw-bg-opacity: 1;background-color:rgb(0 0 0 / var(--tw-bg-opacity, 1))}.bg-opacity-75{--tw-bg-opacity: .75}.text-2xl{font-size:1.5rem;line-height:2rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-yellow-300{--tw-text-opacity: 1;color:rgb(253 224 71 / var(--tw-text-opacity, 1))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--primary-purple: #a855f7;--primary-pink: #ec4899;--primary-cyan: #06b6d4;--secondary-blue: #3b82f6;--success-green: #22c55e;--warning-orange: #f59e0b;--danger-red: #ef4444;--dark-bg: #0f172a;--darker-bg: #1e293b;--darkest-bg: #0c0c0f;--text-primary: #e5e7eb;--text-secondary: #9ca3af;--text-muted: #6b7280;--border-color: #94a3b8;--border-light: rgba(148, 163, 184, .1);--border-medium: rgba(148, 163, 184, .2);--border-heavy: rgba(148, 163, 184, .3);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 20px;--spacing-2xl: 24px;--spacing-3xl: 32px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 18px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--shadow-glow: 0 0 20px rgba(168, 85, 247, .3);--sky-bg: rgba(10,10,10,.85);--sky-text: #D1D1D1;--sky-accent-bg: #ffffff;--sky-accent-text: #000000;--sky-sep: linear-gradient(90deg, transparent, rgba(255,255,255,.5) 20%, rgba(255,255,255,.5) 80%, transparent);--corner-size: 18px;--corner-color: rgba(209,209,209,.9)}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;width:100%;background:var(--dark-bg)}#root{height:100%;width:100%;background:transparent}h1,h2,h3,h4,h5,h6{font-family:Cinzel,serif;font-weight:600;letter-spacing:.5px}.container{max-width:-webkit-fill-available}.top-nav,.nav-categories{background-color:var(--sky-bg)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#0f172a4d;border-radius:4px}::-webkit-scrollbar-thumb{background:#d1d1d11f;border-radius:4px;border:1px solid rgba(15,23,42,.5)}::-webkit-scrollbar-thumb:hover{background:#d1d1d12e}::-moz-selection{background:#a855f74d;color:#fff}::selection{background:#a855f74d;color:#fff}@keyframes glow{0%,to{box-shadow:0 0 20px #a855f74d}50%{box-shadow:0 0 30px #a855f799}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}:root{--sky-bg: rgba(10,10,10,.85);--sky-text: #D1D1D1;--sky-accent-bg: #ffffff;--sky-accent-text: #000000;--sky-sep: linear-gradient(90deg, transparent, rgba(255,255,255,.5) 20%, rgba(255,255,255,.5) 80%, transparent);--corner-size: 18px;--corner-color: rgba(209,209,209,.9)}html,body,#root{height:100%}body{background:var(--sky-bg) url(/assets/bg-skyrim-DbdBCBN0.jpg) center/cover fixed no-repeat!important;background-blend-mode:overlay;color:var(--sky-text)!important;font-family:Roboto Condensed,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif!important;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.modal,.modal-content,.dialog,.panel,.panel-content,.panel-body,.card,.card-body,.story-modal,.campaigns-panel,.dashboard-content,.story-preview-sticky,.story-intro-card,.character-card,.stat-card,.campaign-item,.list-item,.sidebar,.sidebar-content,.page,.content,.container,header,.app{color:var(--sky-text);font-family:Roboto Condensed,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}.btn,.button,.btn-primary,button{background:transparent;color:var(--sky-text);border:1px solid rgba(209,209,209,.08);padding:8px 12px;border-radius:6px;cursor:pointer}.btn-primary,.button.primary{background:#ffffff0f;color:var(--sky-text);border:1px solid rgba(255,255,255,.06)}h1,h2,h3,h4,h5,h6,.section-title,.story-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--sky-text);font-weight:700}hr,.sky-separator,.section-divider{height:1px;border:none;background-image:var(--sky-sep);background-repeat:no-repeat;background-size:100% 1px}.story-modal,.modal-content,.campaigns-panel,.dashboard-content,.story-preview-sticky,.story-intro-card,.character-card,.stat-card,.panel,.card,.dialog{position:relative;padding:.6rem}.story-modal:after,.modal-content:after,.campaigns-panel:after,.dashboard-content:after,.story-preview-sticky:after,.story-intro-card:after,.character-card:after,.stat-card:after,.panel:after,.card:after,.dialog:after{content:none;display:none;background:none;pointer-events:none}.story-modal>*,.modal-content>*,.story-intro-card>*,.character-card>*{position:relative;z-index:1}.story-intro-card,.character-card,.campaign-item,.list-item,.stat-card{width:100%;transition:background-color .12s ease,color .12s ease,transform .12s ease}.story-intro-card.selected,.story-intro-card:hover,.character-card.selected,.character-card:hover,.campaign-item.selected,.campaign-item:hover,.list-item.selected,.list-item:hover,.stat-card.selected,.stat-card:hover{background:var(--sky-accent-bg)!important;color:var(--sky-accent-text)!important;transform:translateY(-2px)}.story-intro-card.selected *,.character-card.selected *,.campaign-item.selected *{color:var(--sky-accent-text)!important}.story-intro-card .story-intro-title:before,.character-card .character-name:before,.campaign-item .campaign-title:before,.list-item .item-title:before{content:"";display:inline-block;width:14px;height:14px;margin-right:10px;vertical-align:middle;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23D1D1D1' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M12 2 L20 12 L12 22 L4 12 Z' /></svg>");background-repeat:no-repeat;background-position:center;filter:grayscale(1) brightness(1)}.dashboard-tabs,.top-nav,.nav-categories{display:flex;gap:12px;align-items:center}.tab-btn,.nav-icon{background:transparent;color:var(--sky-text);border:none;padding:8px 12px;cursor:pointer;position:relative;font-weight:600}.tab-btn:after,.nav-icon:after{content:"";position:absolute;left:8px;right:8px;bottom:-6px;height:1px;background-image:var(--sky-sep);opacity:0;transition:opacity .12s}.tab-btn.active:after,.nav-icon.active:after{content:"";position:absolute;left:50%;transform:translate(-50%);bottom:-16.5px;height:2px;width:200vw;background:linear-gradient(to right,currentColor 0%,currentColor calc(50% - 15px),transparent calc(50% - 15px),transparent calc(50% + 15px),currentColor calc(50% + 15px),currentColor 100%);border-radius:2px;opacity:.5;pointer-events:none;transition:width .12s,opacity .12s;z-index:1}.tab-btn.active:before,.nav-icon.active:before{content:"";position:absolute;left:50%;transform:translate(-50%) rotate(45deg);bottom:-35px;width:30px;height:30px;background:#0a0a0a30;box-shadow:0 1px #00000014 inset;border-top:3px solid var(--sky-accent-bg);border-left:3px solid var(--sky-accent-bg);z-index:2}.tab-btn span,.nav-icon span{text-transform:uppercase;font-size:12px;letter-spacing:1px}.story-section-title,.panel-title{display:flex;align-items:center;gap:12px;padding-bottom:8px;border-bottom:1px solid transparent}.story-section-title:after,.panel-title:after{content:"";flex:1;height:1px;margin-left:12px;background-image:var(--sky-sep)}@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}@media(max-width:640px){.story-intros-grid{grid-template-columns:1fr}.tab-btn span,.nav-icon span{display:none}}
