@import "https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600&family=Crimson+Text:ital,wght@0,400;0,600;1,400&family=Rajdhani:wght@400;500;600;700&display=swap";:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;@media (width<=1024px){font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px;@media (width<=1024px){margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%;@media (width<=1024px){font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.landing-page{min-height:100vh}.hero{text-align:center;background:linear-gradient(180deg, var(--bg-void) 0%, #0d0d14 50%, var(--bg-void) 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:120px 24px 80px;display:flex;position:relative;overflow:hidden}.hero:before{content:"";pointer-events:none;background:radial-gradient(#c9a2270d 0%,#0000 60%);position:absolute;inset:0}.hero-badge{border:1px solid var(--accent-gold-dim);letter-spacing:2px;text-transform:uppercase;color:var(--accent-gold);background:#c9a2271a;border-radius:20px;margin-bottom:32px;padding:6px 16px;font-size:12px;display:inline-block}.hero h1{color:var(--text-primary);max-width:800px;margin-bottom:24px;font-size:56px}.hero h1 span{color:var(--accent-gold)}.hero-subtitle{color:var(--text-secondary);max-width:600px;margin-bottom:48px;font-size:22px}.hero-video{aspect-ratio:16/9;background:var(--bg-surface);border:1px solid var(--accent-gold-dim);border-radius:8px;justify-content:center;align-items:center;width:100%;max-width:900px;margin-bottom:48px;display:flex;position:relative;overflow:hidden}.hero-video:before{content:"";background:linear-gradient(135deg,#c9a2270d 0%,#0000 50%);position:absolute;inset:0}.play-btn{border:2px solid var(--accent-gold);cursor:pointer;z-index:1;background:#c9a22733;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;transition:all .3s;display:flex}.play-btn:before{content:"▶";color:var(--accent-gold);margin-left:4px;font-size:28px}.play-btn:hover{background:var(--accent-gold);transform:scale(1.1)}.play-btn:hover:before{color:var(--bg-void)}.hero-cta{gap:16px;margin-top:16px;display:flex}.features{padding:100px 0}.section-header{text-align:center;margin-bottom:64px}.section-header h2{color:var(--accent-gold);margin-bottom:16px;font-size:36px}.section-header p{color:var(--text-secondary);max-width:500px;margin:0 auto}.features-grid{grid-template-columns:repeat(3,1fr);gap:32px;display:grid}.feature-card{background:var(--bg-surface);text-align:center;border:1px solid #c9a2271a;border-radius:8px;padding:40px 32px;transition:all .4s;position:relative;overflow:hidden}.feature-card:before{content:"";background:linear-gradient(90deg, transparent, var(--accent-gold), transparent);opacity:0;height:3px;transition:opacity .4s;position:absolute;top:0;left:0;right:0}.feature-card:hover{border-color:var(--accent-gold-dim);transform:translateY(-8px)}.feature-card:hover:before{opacity:1}.feature-icon{background:#c9a2271a;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 24px;font-size:32px;display:flex}.feature-card h3{color:var(--text-primary);margin-bottom:12px;font-size:20px}.feature-card p{color:var(--text-secondary);font-size:16px}.testimonial{background:var(--bg-surface);border-top:1px solid #c9a2271a;border-bottom:1px solid #c9a2271a;padding:80px 0}.testimonial-inner{text-align:center;max-width:700px;margin:0 auto}.testimonial-quote{color:var(--text-primary);margin-bottom:24px;font-family:Crimson Text,serif;font-size:24px;font-style:italic}.testimonial-quote:before,.testimonial-quote:after{content:"\""}.testimonial-author{color:var(--accent-gold);letter-spacing:1px;font-size:14px}.pricing{padding:100px 0}.pricing-grid{grid-template-columns:repeat(3,1fr);gap:24px;max-width:1000px;margin:0 auto;display:grid}.pricing-card{background:var(--bg-surface);text-align:center;border:1px solid #c9a22726;border-radius:8px;padding:40px 32px;transition:all .3s;position:relative}.pricing-card.featured{border-color:var(--accent-gold);box-shadow:0 0 40px #c9a2271a}.pricing-card:hover{transform:translateY(-4px);box-shadow:0 8px 40px #0000004d}.pricing-badge{background:var(--accent-gold);color:var(--bg-void);letter-spacing:1px;text-transform:uppercase;border-radius:12px;padding:4px 16px;font-size:11px;font-weight:700;position:absolute;top:-12px;left:50%;transform:translate(-50%)}.pricing-card h3{color:var(--accent-gold);margin-bottom:16px;font-family:Cinzel,serif;font-size:18px}.pricing-price{color:var(--text-primary);margin-bottom:8px;font-size:48px;font-weight:700}.pricing-price span{color:var(--text-muted);font-size:16px}.pricing-desc{color:var(--text-secondary);margin-bottom:32px;font-family:Crimson Text,serif;font-size:15px}.pricing-features{text-align:left;margin-bottom:32px;list-style:none}.pricing-features li{color:var(--text-secondary);border-bottom:1px solid #ffffff0d;align-items:center;gap:12px;padding:10px 0;font-size:14px;display:flex}.pricing-features li:before{content:"✓";color:var(--accent-gold);font-weight:700}.pricing-card .btn-ghost,.pricing-card .btn-primary{width:100%;padding:14px}footer{background:var(--bg-surface);border-top:1px solid #c9a2271a;padding:80px 0 40px}.footer-cta{text-align:center;margin-bottom:64px}.footer-cta h2{color:var(--text-primary);margin-bottom:16px;font-size:32px}.footer-cta p{color:var(--text-secondary);margin-bottom:32px}.footer-links{flex-wrap:wrap;justify-content:center;gap:40px;margin-bottom:40px;display:flex}.footer-links a{color:var(--text-muted);font-size:14px}.footer-links a:hover{color:var(--accent-gold)}.footer-copy{text-align:center;color:var(--text-muted);border-top:1px solid #ffffff0d;padding-top:40px;font-size:13px}@media (width<=768px){.hero h1{font-size:36px}.features-grid,.pricing-grid{grid-template-columns:1fr}.hero-cta{flex-direction:column}}.modal-overlay{backdrop-filter:blur(4px);z-index:200;background:#000c;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-surface);border:1px solid #c9a22733;border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;padding:24px 24px 0;display:flex}.modal-header h2{color:var(--accent-gold);font-size:24px}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:28px;transition:color .3s}.modal-close:hover{color:var(--text-primary)}.modal-form{flex-direction:column;gap:20px;padding:24px;display:flex}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password],.form-group textarea,.form-group select{background:var(--bg-elevated);width:100%;color:var(--text-primary);border:1px solid #c9a22733;border-radius:4px;padding:12px 16px;font-family:Rajdhani,sans-serif;font-size:16px;transition:border-color .3s}.form-group textarea{resize:vertical;min-height:80px}.form-group select{cursor:pointer}.form-group.checkbox label{cursor:pointer;text-transform:none;color:var(--text-primary);align-items:center;gap:12px;font-size:14px;display:flex}.form-group.checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-gold)}.form-hint{color:var(--text-muted);margin-top:4px;font-size:13px}.modal-actions{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}.modal-actions button{justify-content:center;align-items:center;min-width:120px;display:flex}.modal-actions .spinner{border:2px solid var(--bg-void);border-top-color:#0000;width:18px;height:18px}.world-selection-page{background:var(--bg-void);min-height:100vh}.main-content{max-width:1400px;margin:0 auto;padding:72px 32px 80px}.page-header{text-align:center;padding:60px 0 48px}.page-header h1{color:var(--accent-gold);margin-bottom:16px;font-size:42px}.page-header p{color:var(--text-secondary);max-width:600px;margin:0 auto;font-size:20px}.world-section{margin-bottom:48px}.section-title{color:var(--text-muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:24px;padding-left:4px;font-size:14px}.world-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:32px;display:grid}.loading-container{justify-content:center;padding:80px 0;display:flex}.world-card{background:var(--bg-surface);cursor:pointer;border:1px solid #c9a22726;border-radius:12px;transition:all .4s;overflow:hidden}.world-card:hover{border-color:var(--accent-gold);transform:translateY(-8px);box-shadow:0 20px 60px #0006}.world-image{background:var(--bg-elevated);height:180px;position:relative;overflow:hidden}.world-image:before{content:"";background:linear-gradient(180deg, transparent 50%, var(--bg-surface) 100%);z-index:1;position:absolute;inset:0}.world-image-placeholder{opacity:.5;justify-content:center;align-items:center;font-size:48px;display:flex;position:absolute;inset:0}.world-card.sherlock .world-image{background:linear-gradient(135deg,#1a1520,#2d2535)}.world-card.frankenstein .world-image{background:linear-gradient(135deg,#1a0a0a,#2d1515)}.world-card.oz .world-image{background:linear-gradient(135deg,#0a1a15,#152d25)}.world-card.alice .world-image{background:linear-gradient(135deg,#15101a,#251d2d)}.world-info{padding:24px}.world-info h3{color:var(--text-primary);margin-bottom:4px;font-size:22px}.world-author{color:var(--accent-gold);margin-bottom:12px;font-family:Crimson Text,serif;font-size:15px;font-style:italic}.world-desc{color:var(--text-secondary);margin-bottom:16px;font-family:Crimson Text,serif;font-size:16px;line-height:1.6}.world-tags{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.tag{letter-spacing:.5px;text-transform:uppercase;border-radius:16px;padding:4px 12px;font-size:12px;font-weight:600}.tag.mistério,.tag.mystery{color:#6a9fd4;background:#2a4a6a4d;border:1px solid #6a9fd44d}.tag.gothic,.tag.gótico{color:#d46a6a;background:#8b000033;border:1px solid #8b00004d}.tag.fantasy,.tag.fantasia{color:#7ab86a;background:#2d5a2733;border:1px solid #2d5a274d}.tag.adventure,.tag.aventura{color:#c9a227;background:#6b5a3d4d;border:1px solid #c9a2274d}.tag.free,.tag.domínio-público{color:var(--accent-gold);border:1px solid var(--accent-gold-dim);background:#c9a2271a}.tag.horror{color:#d46a6a;background:#8b000033;border:1px solid #8b00004d}.tag.medieval{color:#c9a227;background:#6b5a3d4d;border:1px solid #c9a2274d}.tag.sci-fi{color:#6a9fd4;background:#2a4a6a4d;border:1px solid #6a9fd44d}.tag.custom{color:var(--accent-gold);border:1px solid var(--accent-gold-dim);background:#c9a2271a}.world-card .btn-primary{width:100%;padding:14px;font-size:14px}.custom-world-card{background:linear-gradient(135deg, var(--bg-surface), var(--bg-elevated));border:2px dashed var(--accent-gold-dim);cursor:pointer;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;min-height:380px;transition:all .3s;display:flex}.custom-world-card:hover{border-color:var(--accent-gold);background:linear-gradient(135deg, var(--bg-elevated), var(--bg-modal))}.custom-icon{opacity:.7;margin-bottom:20px;font-size:56px}.custom-world-card h3{color:var(--text-primary);margin-bottom:8px;font-size:20px}.custom-world-card p{color:var(--text-secondary);text-align:center;max-width:260px;margin-bottom:20px;font-family:Crimson Text,serif;font-size:16px}.upload-hint{color:var(--text-muted);align-items:center;gap:8px;font-size:13px;display:flex}.world-selection-page>footer{background:var(--bg-surface);text-align:center;border-top:1px solid #c9a2271a;padding:40px}.world-selection-page>footer p{color:var(--text-muted);font-size:14px}.header{z-index:100;backdrop-filter:blur(10px);background:#0a0a0ff2;border-bottom:1px solid #c9a22733;padding:0 24px;position:fixed;top:0;left:0;right:0}.header-inner{justify-content:space-between;align-items:center;max-width:1400px;height:72px;margin:0 auto;display:flex}.logo{align-items:center;gap:10px;display:flex}.logo-icon{font-size:24px}.logo-text{color:var(--accent-gold);letter-spacing:2px;font-family:Cinzel,serif;font-size:18px;font-weight:600}.header-center{align-items:center;gap:24px;display:flex}.world-name{color:var(--text-primary);letter-spacing:1px;font-family:Cinzel,serif;font-size:14px}.user-menu{align-items:center;gap:16px;display:flex}.username{color:var(--text-secondary);font-size:14px}@media (width<=768px){.world-grid{grid-template-columns:1fr}.header-center{display:none}.page-header h1{font-size:32px}}.auth-page{background:linear-gradient(180deg, var(--bg-void) 0%, #0d0d14 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-container{background:var(--bg-surface);border:1px solid #c9a22733;border-radius:12px;width:100%;max-width:400px;padding:48px 40px}.auth-header{text-align:center;margin-bottom:40px}.auth-header h1{color:var(--accent-gold);margin-bottom:12px;font-size:32px}.auth-header p{color:var(--text-secondary);font-size:16px}.auth-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;display:flex}.form-group label{color:var(--text-secondary);letter-spacing:1px;text-transform:uppercase;margin-bottom:8px;font-size:13px}.form-group input{background:var(--bg-elevated);width:100%;color:var(--text-primary);border:1px solid #c9a22733;border-radius:4px;padding:14px 16px;font-size:16px;transition:border-color .3s}.form-group input:focus{border-color:var(--accent-gold);outline:none}.form-group input::placeholder{color:var(--text-muted)}.error-message{border:1px solid var(--accent-danger);color:#d46a6a;text-align:center;background:#8b000033;border-radius:4px;padding:12px 16px;font-size:14px}.auth-submit{justify-content:center;align-items:center;width:100%;margin-top:8px;padding:14px;font-size:16px;display:flex}.auth-submit .spinner{border:2px solid var(--bg-void);border-top-color:#0000;width:20px;height:20px}.auth-footer{text-align:center;border-top:1px solid #ffffff0d;margin-top:32px;padding-top:24px}.auth-footer p{color:var(--text-muted);font-family:Rajdhani,sans-serif;font-size:14px}.auth-footer a{color:var(--accent-gold);cursor:pointer}.auth-footer a:hover{color:var(--text-primary)}.create-book-world-page{max-width:800px;margin:0 auto;padding:2rem}.page-header{margin-bottom:2rem}.back-button{color:var(--color-primary,#646cff);cursor:pointer;background:0 0;border:none;margin-bottom:1rem;padding:0;font-size:.9rem}.back-button:hover{text-decoration:underline}.page-header h1{margin-bottom:.5rem;font-size:2rem}.subtitle{color:var(--color-text-secondary,#666);font-size:1.1rem}.page-content{flex-direction:column;gap:2rem;display:flex}.intro-section{background:var(--color-bg-secondary,#f5f5f5);border-radius:8px;padding:1.5rem}.intro-section h2{margin-bottom:1rem;font-size:1.25rem}.features-list{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.features-list li{align-items:center;gap:.75rem;display:flex}.feature-icon{font-size:1.25rem}.feature-text{font-size:.95rem}.upload-section{background:var(--color-bg-primary,#fff);border:1px solid var(--color-border,#ddd);border-radius:8px;padding:1.5rem}.upload-section h2{margin-bottom:.5rem;font-size:1.25rem}.upload-hint{color:var(--color-text-secondary,#666);margin-bottom:1.5rem;font-size:.85rem}.book-upload{flex-direction:column;gap:1rem;display:flex}.upload-zone{border:2px dashed var(--color-border,#ddd);text-align:center;cursor:pointer;border-radius:8px;padding:3rem 2rem;transition:all .2s;position:relative}.upload-zone:hover,.upload-zone.dragging{border-color:var(--color-primary,#646cff);background:var(--color-bg-hover,#f0f0ff)}.upload-zone.has-file{border-style:solid;border-color:var(--color-success,#4caf50)}.upload-icon{margin-bottom:1rem;font-size:3rem;display:block}.upload-text{margin-bottom:.25rem;font-size:1rem;font-weight:500;display:block}.upload-subtext{color:var(--color-text-secondary,#666);font-size:.85rem;display:block}.file-input{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;top:0;left:0}.selected-file{flex-direction:column;align-items:center;gap:.5rem;display:flex}.file-icon{font-size:2.5rem}.file-name{font-weight:500}.file-size{color:var(--color-text-secondary,#666);font-size:.85rem}.upload-progress{flex-direction:column;gap:.5rem;display:flex}.upload-progress.error .progress-message{color:var(--color-error,#f44336)}.upload-progress.complete .progress-message{color:var(--color-success,#4caf50)}.progress-bar{background:var(--color-bg-secondary,#e0e0e0);border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:var(--color-primary,#646cff);height:100%;transition:width .3s}.upload-progress.complete .progress-fill{background:var(--color-success,#4caf50)}.upload-progress.error .progress-fill{background:var(--color-error,#f44336)}.progress-message{text-align:center;font-size:.9rem}.upload-button,.retry-button{cursor:pointer;border:none;border-radius:6px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;transition:background .2s}.upload-button{background:var(--color-primary,#646cff);color:#fff}.upload-button:hover{background:var(--color-primary-hover,#535ae0)}.retry-button{background:var(--color-bg-secondary,#e0e0e0);color:var(--color-text-primary,#333)}.retry-button:hover{background:var(--color-bg-hover,#d0d0d0)}.tips-section{background:var(--color-bg-secondary,#f5f5f5);border-radius:8px;padding:1.5rem}.tips-section h3{margin-bottom:1rem;font-size:1rem}.tips-section ul{margin:0;padding-left:1.25rem}.tips-section li{color:var(--color-text-secondary,#555);margin-bottom:.5rem;font-size:.9rem}.game-view{background:var(--bg-primary);height:100vh;color:var(--text-primary);flex-direction:column;display:flex;position:relative}.connection-status{text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:8px;padding:8px 16px;font-size:12px;font-weight:600;display:flex}.connection-status.connected{color:var(--accent-success);background:#2ed57326}.connection-status.disconnected{color:var(--accent);background:#e9456026}.status-dot{background:currentColor;border-radius:50%;width:8px;height:8px;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.game-main{flex:1;display:flex;overflow:hidden}.narrative-viewport{flex-direction:column;flex:1;padding:20px;display:flex;overflow:hidden}.narrative-header{border-bottom:1px solid var(--border-color);margin-bottom:16px;padding-bottom:16px}.narrative-header h2{color:var(--accent-gold);margin:0 0 8px;font-family:Cinzel,serif;font-size:24px}.location-description{color:var(--text-secondary);margin:0;font-size:14px;font-style:italic}.messages-container{flex-direction:column;flex:1;gap:16px;padding:16px 0;display:flex;overflow-y:auto}.message{border-radius:8px;max-width:80%;padding:12px 16px;animation:.3s messageIn}@keyframes messageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-narrative{background:var(--bg-secondary);border-left:3px solid var(--accent-gold);align-self:flex-start}.message-player{border-right:3px solid var(--color-blue);text-align:right;background:#3b82f626;align-self:flex-end}.message-dice{border-left:3px solid var(--color-purple);background:#a855f726;align-self:flex-start}.message-system{border:1px dashed var(--border-color);text-align:center;color:var(--text-secondary);background:#ffffff0d;align-self:center;font-size:13px}.message-combat{border-left:3px solid var(--accent);background:#e9456026;align-self:flex-start}.message-sender{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:4px;font-size:11px;font-weight:600;display:block}.message-content{white-space:pre-wrap;font-size:15px;line-height:1.6}.message-time{color:var(--text-secondary);opacity:.7;margin-top:8px;font-size:11px;display:block}.dice-results{flex-direction:column;gap:4px;margin-top:8px;display:flex}.dice-result{align-items:center;gap:8px;display:flex}.dice-total{color:var(--accent-gold);font-family:JetBrains Mono,monospace;font-size:20px;font-weight:700}.dice-breakdown{color:var(--text-secondary);font-family:JetBrains Mono,monospace;font-size:13px}.dice-critical{color:var(--color-green);text-transform:uppercase;font-size:12px;font-weight:700}.dice-fumble{color:var(--accent);text-transform:uppercase;font-size:12px;font-weight:700}.input-area{border-top:1px solid var(--border-color);align-items:flex-end;gap:12px;padding-top:16px;display:flex}.input-area textarea{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);resize:none;border-radius:8px;flex:1;min-height:44px;max-height:120px;padding:12px 16px;font-family:inherit;font-size:15px}.input-area textarea:focus{border-color:var(--accent-gold);outline:none}.input-area textarea:disabled{opacity:.5;cursor:not-allowed}.btn-send{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:12px 24px;font-size:14px;font-weight:600;transition:all .2s}.btn-send:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.btn-send:disabled{opacity:.5;cursor:not-allowed;transform:none}.game-sidebar{background:var(--bg-secondary);border-left:1px solid var(--border-color);flex-direction:column;gap:16px;width:300px;padding:16px;display:flex;overflow-y:auto}.game-sidebar.collapsed{width:0;padding:0;overflow:hidden}.sidebar-toggle{background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;text-align:left;border-radius:6px;padding:10px 12px;font-size:14px;transition:all .2s}.sidebar-toggle:hover{background:var(--bg-hover);border-color:var(--accent-gold)}.character-sheet{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:16px}.character-sheet h3{color:var(--accent-gold);margin:0 0 8px;font-family:Cinzel,serif;font-size:18px}.char-meta{color:var(--text-secondary);gap:8px;margin-bottom:16px;font-size:12px;display:flex}.char-meta span:before{content:"•";margin-right:8px}.char-meta span:first-child:before{display:none}.char-stats{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.stat{background:var(--bg-secondary);border-radius:4px;justify-content:space-between;padding:6px 10px;font-size:13px;display:flex}.stat-name{color:var(--text-secondary);font-weight:600}.stat-value{color:var(--text-primary);font-family:JetBrains Mono,monospace}.location-panel,.npcs-panel{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:16px}.location-panel h4,.npcs-panel h4{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin:0 0 12px;font-size:11px;font-weight:600}.location-name{color:var(--accent-gold);margin:0 0 8px;font-family:Cinzel,serif;font-size:16px}.location-desc{color:var(--text-secondary);margin:0 0 12px;font-size:13px;line-height:1.5}.location-connections{margin-top:8px}.connections-label{color:var(--text-secondary);margin-bottom:6px;font-size:11px;display:block}.connections-list,.npcs-list{flex-wrap:wrap;gap:6px;margin:0;padding:0;list-style:none;display:flex}.connection-tag{background:var(--bg-secondary);color:var(--text-secondary);border-radius:4px;padding:4px 10px;font-size:12px}.no-location{color:var(--text-secondary);margin:0;font-size:13px;font-style:italic}.npc-item{border-bottom:1px solid var(--border-color);flex-direction:column;padding:8px 0;display:flex}.npc-item:last-child{border-bottom:none}.npc-name{color:var(--text-primary);font-size:14px;font-weight:500}.npc-role{color:var(--text-secondary);font-size:12px}@media (width<=768px){.game-sidebar{z-index:100;background:var(--bg-secondary);transition:transform .3s;position:absolute;top:0;bottom:0;right:0;transform:translate(100%)}.game-sidebar.open{transform:translate(0)}.message{max-width:95%}}.character-creation-page{background:var(--bg-primary);min-height:100vh;color:var(--text-primary);padding:40px 20px}.creation-container{max-width:800px;margin:0 auto}.creation-header{margin-bottom:40px}.back-to-worlds{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;margin-bottom:20px;padding:0;font-size:14px;display:flex}.back-to-worlds:hover{color:var(--accent-gold)}.step-indicator{align-items:center;gap:12px;font-size:14px;display:flex}.step{color:var(--text-secondary);border-radius:4px;padding:6px 12px;transition:all .2s}.step.active{color:var(--accent-gold);background:#d4af3726;font-weight:600}.step-divider{color:var(--border-color)}.creation-step{animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.creation-step h2{color:var(--accent-gold);margin:0 0 8px;font-family:Cinzel,serif;font-size:32px}.step-hint{color:var(--text-secondary);margin:0 0 32px;font-size:16px}.back-btn{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:6px;margin-bottom:24px;padding:8px 16px;font-size:14px;transition:all .2s}.back-btn:hover{border-color:var(--accent-gold);color:var(--accent-gold)}.options-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.option-card{background:var(--bg-secondary);border:1px solid var(--border-color);cursor:pointer;text-align:center;border-radius:12px;flex-direction:column;align-items:center;gap:8px;padding:24px 20px;transition:all .2s;display:flex}.option-card:hover{border-color:var(--accent-gold);background:var(--bg-hover);transform:translateY(-2px)}.option-icon{margin-bottom:8px;font-size:32px}.option-name{color:var(--text-primary);font-size:18px;font-weight:600}.option-desc{color:var(--text-secondary);font-size:13px;line-height:1.4}.name-input-container{flex-direction:column;gap:16px;max-width:500px;display:flex}.name-input{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:8px;width:100%;padding:16px 20px;font-family:inherit;font-size:18px}.name-input:focus{border-color:var(--accent-gold);outline:none}.name-input::placeholder{color:var(--text-secondary)}.btn-create{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:16px 32px;font-size:16px;font-weight:600;transition:all .2s}.btn-create:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.btn-create:disabled{opacity:.5;cursor:not-allowed;transform:none}.error-message{color:var(--accent);margin:0;font-size:14px}:root{--bg-void:#0a0a0f;--bg-surface:#141418;--bg-elevated:#1e1e24;--bg-modal:#282830;--text-primary:#e8e4d9;--text-secondary:#9a9590;--text-muted:#5c5850;--accent-gold:#c9a227;--accent-gold-dim:#8a6f1a;--accent-danger:#8b0000;--accent-success:#2d5a27;--accent-info:#2a4a6a;--dice-roll:#4a7c59;--combat:#6b1c1c;--npc-speech:#3d3d6b;--dm-narration:#6b5a3d}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-void);color:var(--text-primary);letter-spacing:.5px;min-height:100vh;font-family:Rajdhani,sans-serif;font-weight:500;line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{text-transform:uppercase;letter-spacing:2px;font-family:Cinzel,serif}p{font-family:Crimson Text,Georgia,serif;font-size:18px;line-height:1.7}a{color:var(--accent-gold);text-decoration:none;transition:color .3s}a:hover{color:var(--text-primary)}button{cursor:pointer;border:none;outline:none;font-family:Rajdhani,sans-serif}input,textarea{font-family:Rajdhani,sans-serif}.btn-ghost{border:1px solid var(--accent-gold-dim);color:var(--accent-gold);letter-spacing:1px;text-transform:uppercase;cursor:pointer;background:0 0;border-radius:4px;padding:10px 24px;font-size:14px;font-weight:600;transition:all .3s}.btn-ghost:hover{background:var(--accent-gold);color:var(--bg-void)}.btn-primary{background:var(--accent-gold);color:var(--bg-void);letter-spacing:1px;text-transform:uppercase;cursor:pointer;border:none;border-radius:4px;padding:10px 24px;font-size:14px;font-weight:700;transition:all .3s}.btn-primary:hover{background:var(--text-primary);transform:translateY(-2px);box-shadow:0 4px 20px #c9a2274d}.btn-primary:disabled{background:var(--text-muted);cursor:not-allowed;transform:none}.container{max-width:1200px;margin:0 auto;padding:0 24px}.spinner{border:3px solid var(--bg-elevated);border-top-color:var(--accent-gold);border-radius:50%;width:24px;height:24px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.form-group{margin-bottom:20px}.form-group label{color:var(--text-secondary);letter-spacing:1px;text-transform:uppercase;margin-bottom:8px;font-size:13px;display:block}.form-group input,.form-group textarea,.form-group select{background:var(--bg-surface);width:100%;color:var(--text-primary);border:1px solid #c9a22733;border-radius:4px;padding:12px 16px;font-size:16px;transition:border-color .3s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--accent-gold);outline:none}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-group .error-message{color:var(--accent-danger);margin-top:6px;font-size:13px}.toast{z-index:1000;border-radius:8px;padding:16px 24px;font-family:Rajdhani,sans-serif;font-weight:600;animation:.3s slideIn;position:fixed;bottom:24px;right:24px}.toast.error{background:var(--accent-danger);color:var(--text-primary)}.toast.success{background:var(--accent-success);color:var(--text-primary)}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}#root{min-height:100vh}.placeholder{min-height:100vh;color:var(--text-muted);justify-content:center;align-items:center;font-size:24px;display:flex}
