@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@400;700;900&family=Inter:wght@300;400;500;600&display=swap";:root{--bg-primary: #0a0a0a;--bg-secondary: #141414;--bg-card: #1a1a1a;--bg-input: #222;--accent: #8b0000;--accent-glow: rgba(139, 0, 0, .3);--text-primary: #e8e8e8;--text-secondary: #999;--text-muted: #666;--border: #2a2a2a;--success: #2ecc71;--warning: #f39c12;--glass-bg: rgba(26, 26, 26, .4);--glass-border: rgba(255, 255, 255, .08)}.glass-card{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:0 8px 32px #0000005e;border-radius:16px;transition:transform .2s ease,border-color .2s ease}.glass-card:hover{border-color:#8b00004d}.card-title-text{font-family:Cinzel,serif;font-size:.85rem;letter-spacing:2px;color:var(--accent);text-shadow:0 0 10px rgba(139,0,0,.5)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px}.loading-screen h1{font-family:Cinzel,serif;font-size:1.8rem;color:var(--accent)}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;background:radial-gradient(ellipse at center,#1a0a0a,#0a0a0a 70%)}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:40px 30px;width:100%;max-width:400px;box-shadow:0 20px 60px #00000080,0 0 30px var(--accent-glow)}.login-title{font-family:Cinzel,serif;font-size:1.6rem;color:var(--accent);text-align:center;margin-bottom:4px}.login-subtitle{text-align:center;color:var(--text-secondary);font-size:.8rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:30px}.login-toggle{text-align:center;margin-top:20px;color:var(--text-secondary);font-size:.85rem}.btn-link{background:none;border:none;color:var(--accent);cursor:pointer;font-weight:600;margin-left:6px;text-decoration:underline}.error-text{color:#f44;font-size:.85rem;text-align:center;margin:10px 0;padding:8px;background:#ff44441a;border-radius:8px}.success-text{color:#2ecc71;font-size:.85rem;text-align:center;margin:10px 0;padding:8px;background:#2ecc711a;border-radius:8px}.login-divider{display:flex;align-items:center;text-align:center;margin:20px 0;color:var(--text-muted);font-size:.8rem}.login-divider:before,.login-divider:after{content:"";flex:1;border-bottom:1px solid var(--border)}.login-divider:not(:empty):before{margin-right:.5em}.login-divider:not(:empty):after{margin-left:.5em}.btn-google{width:100%;padding:12px;background:#fff;color:#333;border:none;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;transition:all .2s}.btn-google:hover{background:#f1f1f1;transform:translateY(-1px)}.ficha-container{min-height:100vh;background:var(--bg-primary)}.btn-primary{width:100%;padding:14px;background:var(--accent);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:10px;transition:all .2s}.btn-primary:hover{background:#a00000;transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-outline{padding:10px 16px;background:transparent;color:var(--text-primary);border:1px solid var(--border);border-radius:10px;font-size:.9rem;cursor:pointer;transition:all .2s}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.btn-small{padding:6px 12px;font-size:.8rem;border-radius:6px}.btn-back{background:none;border:none;color:var(--text-secondary);font-size:.9rem;cursor:pointer;padding:4px 8px}.btn-back:hover{color:#fff}.app-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.header-title{font-family:Cinzel,serif;font-size:1.1rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;text-align:center;margin:0 8px}.header-user{display:flex;align-items:center;gap:10px}.user-name{font-size:.8rem;color:var(--text-secondary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.save-indicator{font-size:.8rem;color:var(--text-secondary);min-width:30px;text-align:right}.home-container{min-height:100vh;background:var(--bg-primary)}.home-content{padding:20px 16px;max-width:600px;margin:0 auto}.section-heading{font-family:Cinzel,serif;font-size:1.1rem;color:var(--text-primary);margin-bottom:16px}.loading-text{color:var(--text-secondary);text-align:center;padding:40px 0}.empty-state{text-align:center;padding:40px 20px;color:var(--text-secondary)}.empty-hint{font-size:.85rem;color:var(--text-muted);margin-top:6px}.mesas-grid{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.mesa-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px;cursor:pointer;transition:all .2s}.mesa-card:hover{border-color:var(--accent);box-shadow:0 0 20px var(--accent-glow);transform:translateY(-2px)}.mesa-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.mesa-nome{font-size:1.05rem;font-weight:600;color:#fff}.role-badge{font-size:.75rem;padding:4px 10px;border-radius:20px;font-weight:600}.role-badge.mestre{background:#8b000033;color:#f66;border:1px solid rgba(139,0,0,.3)}.role-badge.jogador{background:#2ecc711a;color:#2ecc71;border:1px solid rgba(46,204,113,.2)}.mesa-code{font-size:.8rem;color:var(--text-secondary)}.mesa-code strong{color:#fff;letter-spacing:2px;font-family:monospace}.home-actions{display:flex;flex-direction:column;gap:12px;margin-top:20px}.inline-form{display:flex;gap:8px;align-items:center}.inline-form .field-input{flex:1}.code-input{font-family:monospace;letter-spacing:3px;text-align:center;font-size:1.1rem;text-transform:uppercase}.mesa-code-banner{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:14px;text-align:center;margin-bottom:24px;font-size:.9rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;gap:12px}.mesa-code-banner strong{color:#fff;font-family:monospace;letter-spacing:3px;font-size:1.2rem}.mestre-container{min-height:100vh;background:var(--bg-primary)}.mestre-content{padding:20px 16px;max-width:700px;margin:0 auto}.jogadores-grid{display:flex;flex-direction:column;gap:12px}.jogador-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px;display:flex;align-items:center;justify-content:space-between;gap:12px;transition:all .2s}.jogador-card:hover{border-color:var(--accent)}.jogador-info{flex:1;cursor:pointer}.jogador-nome{font-size:1rem;font-weight:600;margin-bottom:4px}.jogador-stats{display:flex;gap:12px;flex-wrap:wrap}.jogador-stats .stat{font-size:.8rem;color:var(--text-secondary);background:var(--bg-primary);padding:2px 8px;border-radius:4px}.btn-xp{background:#8b000033;border:1px solid var(--accent);color:#f66;padding:8px 14px;border-radius:8px;cursor:pointer;font-size:.85rem;font-weight:600;white-space:nowrap;transition:all .2s}.btn-xp:hover{background:var(--accent);color:#fff}.xp-feedback{text-align:center;color:var(--success);font-weight:600;padding:10px;margin-top:12px}.readonly-banner{text-align:center;padding:8px;background:#2ecc711a;color:#2ecc71;font-size:.8rem;font-weight:600;letter-spacing:1px}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:24px;width:100%;max-width:400px;box-shadow:0 20px 60px #00000080}.modal-card h3{font-family:Cinzel,serif;margin-bottom:20px;text-align:center}.modal-actions{display:flex;gap:10px;margin-top:20px}.modal-actions .btn-primary,.modal-actions .btn-outline{flex:1;margin-top:0}.xp-modal-value{font-size:1.4rem;min-width:40px}.notif-banner{display:flex;flex-direction:column;gap:4px;padding:8px 12px;background:#8b00001a;border-bottom:1px solid var(--accent)}.notif-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-card);border-radius:8px;cursor:pointer;transition:all .2s}.notif-item:hover{background:var(--bg-secondary)}.notif-icon{font-size:1.1rem}.notif-text{flex:1;font-size:.85rem;color:#fff;font-weight:500}.notif-dismiss{color:var(--text-muted);font-size:.8rem}.xp-display{display:flex;flex-direction:column;gap:10px}.xp-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.xp-available{border-top:1px solid var(--border);padding-top:10px;margin-top:4px}.tab-bar{display:flex;overflow-x:auto;scrollbar-width:none;background:var(--bg-secondary);border-bottom:1px solid var(--border);position:sticky;top:49px;z-index:99}.tab-bar::-webkit-scrollbar{display:none}.tab-btn{flex:1;min-width:70px;background:none;border:none;color:var(--text-muted);padding:8px 4px 6px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:2px;border-bottom:2px solid transparent;transition:all .2s}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-btn:hover{color:var(--text-primary)}.tab-icon{font-size:1.1rem}.tab-label{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.tab-content{padding:12px;max-width:700px;margin:0 auto}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;margin-bottom:12px;overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--border)}.card-header h3{font-family:Cinzel,serif;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--text-primary)}.collapse-icon{color:var(--text-muted);font-size:.9rem}.card-body{padding:12px 16px}.field-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.field-label{font-size:.8rem;color:var(--text-secondary);min-width:90px;flex-shrink:0}.field-input{flex:1;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text-primary);font-size:.9rem;font-family:Inter,sans-serif;transition:border-color .2s}.field-input:focus{outline:none;border-color:var(--accent)}.field-input[readOnly]{opacity:.7;cursor:default}.counter-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.03)}.counter-row:last-child{border-bottom:none}.counter-label{font-size:.85rem;color:var(--text-primary)}.counter-controls{display:flex;align-items:center;gap:6px}.btn-counter{width:30px;height:30px;border-radius:50%;border:1px solid var(--border);background:var(--bg-input);color:var(--text-primary);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.btn-counter:hover{border-color:var(--accent);color:var(--accent)}.counter-value{font-size:1rem;font-weight:600;min-width:24px;text-align:center;color:#fff}.trait-row,.weapon-row,.expanded-trait-row{display:flex;gap:10px;margin-bottom:8px;align-items:center}.expanded-trait-row{flex-direction:column;align-items:stretch;gap:4px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.05)}.expanded-trait-row:last-child{border-bottom:none}.weapon-damage{width:100px;flex:none}.btn-add{width:100%;padding:10px;background:transparent;border:1px dashed var(--border);border-radius:8px;color:var(--text-secondary);font-size:.85rem;cursor:pointer;margin-top:8px;transition:all .2s}.btn-add:hover{border-color:var(--accent);color:var(--accent)}.btn-delete{width:26px;height:26px;border-radius:50%;border:1px solid rgba(255,50,50,.3);background:#ff32321a;color:#f55;font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.btn-delete:hover{background:#ff32324d;border-color:#ff323280}.editable-label{flex:1;min-width:80px}.tracker-dots{display:flex;gap:6px;flex-wrap:wrap;padding:8px 0}.dot{width:28px;height:28px;border-radius:50%;cursor:pointer;transition:all .15s}.dot.filled{background:var(--accent);border:2px solid #a00000;box-shadow:0 0 6px var(--accent-glow)}.dot.empty{background:transparent;border:2px solid var(--text-muted)}.dot:hover{transform:scale(1.15)}.section-title{font-size:.7rem;font-weight:600;color:#ccc;text-transform:uppercase;letter-spacing:1px;margin:10px 0 4px}.health-row-v2{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#ffffff05;border-radius:12px;margin-bottom:8px;transition:all .2s;border:1px solid rgba(255,255,255,.05)}.health-row-v2.clickable:hover{background:#8b000014;border-color:#8b000033}.health-row-v2.is-damaged{background:#8b00001f;border-color:#8b00004d}.health-info-group{display:flex;flex-direction:column;gap:2px}.health-label-v2{font-size:.95rem;font-weight:600;color:#fff}.health-penalty-v2{font-size:.75rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase}.health-box-large{width:34px;height:34px;border:1px solid rgba(255,255,255,.4);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:#f33;font-weight:900;background:#00000080;box-shadow:0 0 10px #ffffff0d;transition:all .2s;pointer-events:none}.is-damaged .health-box-large{border-color:var(--accent);background:#8b000040;box-shadow:0 0 15px var(--accent-glow)}.health-row.clickable{cursor:pointer}.health-row.clickable:hover{background:#ffffff05}.health-check{margin-left:8px;pointer-events:none}.weapon-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}.weapon-damage{max-width:80px}.trait-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}.trait-row .field-input{flex:1}.text-area{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;padding:12px;color:var(--text-primary);font-size:.9rem;font-family:Inter,sans-serif;resize:vertical;transition:border-color .2s}.text-area:focus{outline:none;border-color:var(--accent)}.info-banner{text-align:center;padding:10px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;font-size:.8rem;color:var(--text-secondary);margin-top:8px}.info-banner strong{color:#fff}@media(max-width:600px){.health-row-v2{padding:16px;margin-bottom:10px}.health-box-large{width:38px;height:38px;font-size:1.4rem}.tab-btn{min-width:65px;padding:10px 2px}.tab-label{display:block;font-size:.55rem}.field-row{flex-direction:column;align-items:stretch;gap:6px}.field-label{min-width:unset;font-size:.75rem;opacity:.8}}@media(max-width:420px){.header-title{font-size:.85rem}.tab-btn{min-width:50px}.tab-label{font-size:.5rem}}.clickable-note{cursor:pointer;padding:12px;background:#ffffff08;border-radius:8px;border:1px solid rgba(255,255,255,.05);margin-bottom:10px;transition:all .2s}.clickable-note:hover{background:#ffffff14;border-color:var(--accent)}.note-indicator{float:right;font-size:.75rem;color:var(--accent);background:#8b000033;padding:2px 8px;border-radius:4px;font-weight:500}.note-preview{font-size:.85rem;color:var(--text-muted);margin-top:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4}.wide-modal{width:95%!important;max-width:800px!important;height:80vh;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.1)}.btn-close{background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer}.modal-textarea{flex:1;width:100%;background:#0003;border-color:#ffffff1a;padding:15px;font-size:1rem;line-height:1.6;resize:none;border-radius:8px}.pwa-install-btn{position:fixed;bottom:80px;right:20px;background:var(--accent);color:#fff;border:none;padding:12px 20px;border-radius:50px;font-weight:600;box-shadow:0 4px 15px #0006;z-index:1000;cursor:pointer;animation:bounce 2s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}
