@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(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);box-shadow:0 8px 32px #00000080;border-radius:16px;transition:all .3s cubic-bezier(.4,0,.2,1)}.glass-card:hover{border-color:#8b000066;background:#ffffff05;transform:translateY(-2px);box-shadow:0 12px 40px #0009,0 0 15px var(--accent-glow)}.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}.floating-dock{position:fixed;top:50%;left:8px;transform:translateY(-50%);z-index:200;display:flex;flex-direction:column;gap:2px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:18px;padding:10px 6px;box-shadow:0 8px 32px #00000080,0 0 12px var(--accent-glow)}.dock-item{display:flex;flex-direction:column;align-items:center;justify-content:center;width:65px;height:65px;background:none;border:none;border-left:3px solid transparent;border-radius:14px;color:var(--text-muted);cursor:pointer;transition:all .2s;position:relative}.dock-item:hover{background:#ffffff0d;color:var(--text-primary)}.dock-item.active{background:#8b00001f;color:var(--accent);border-left-color:var(--accent);box-shadow:inset 0 0 8px #8b000026}.dock-item:hover:after{content:attr(title);position:absolute;left:66px;top:50%;transform:translateY(-50%);background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);padding:4px 10px;border-radius:8px;font-size:.75rem;white-space:nowrap;z-index:9999;box-shadow:0 4px 12px #0006;pointer-events:none}.dock-icon{display:flex;align-items:center}.dock-label{font-size:.6rem;margin-top:4px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;text-align:center;opacity:.8}.tab-content{padding:16px 12px 12px;max-width:700px;margin:0 auto}.tab-content.with-dock{margin-left:84px}@media(max-width:768px){.app-container{flex-direction:column}.floating-dock{border-top-color:var(--accent)}.dock-item:hover:after{display:none}.tab-content.with-dock{margin-left:70px}}.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}.locked-field{opacity:.6}.locked-field .btn-counter,.locked-field .btn-delete{background:#0003!important;border-color:#ffffff1a!important;color:#ffffff4d!important;cursor:not-allowed}.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}.mestre-d20-overlay{position:fixed;inset:0;background:#000000d9;z-index:99999;display:flex;flex-direction:column;justify-content:center;align-items:center;perspective:1200px;animation:fadeIn .3s ease-out}.mestre-d20-cube{position:relative;width:100px;height:100px;transform-style:preserve-3d;transition:transform .5s}.mestre-d20-cube.rolling{animation:spin3D .6s infinite linear,bounceDice .4s infinite alternate ease-in-out}.mestre-d20-face{position:absolute;width:100%;height:100%;background:radial-gradient(circle at center,#5a189a,#2e005c);border:2px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:900;color:#fff;text-shadow:0 0 10px rgba(0,0,0,.9);box-shadow:inset 0 0 20px #000000e6;backface-visibility:inherit;clip-path:polygon(50% 0%,100% 25%,50% 100%,0% 25%)}.mestre-d20-result{margin-top:50px;font-family:Cinzel,serif;font-size:3rem;color:#fff;text-shadow:0 0 20px #9d4edd;animation:popIn .5s cubic-bezier(.175,.885,.32,1.275)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.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}.accordion-item{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;margin-bottom:12px;overflow:hidden}.accordion-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--border)}.accordion-header h3{font-family:Cinzel,serif;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--text-primary)}@media(max-width:600px){.health-row-v2{padding:16px;margin-bottom:10px}.health-box-large{width:38px;height:38px;font-size:1.4rem}.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}}.update-banner{position:fixed;top:0;left:0;right:0;background:var(--accent);color:#fff;padding:10px 20px;display:flex;justify-content:space-between;align-items:center;z-index:10001;font-weight:600;box-shadow:0 2px 10px #00000080;animation:slideDown .3s ease-out}.update-banner button{background:#fff;color:var(--accent);border:none;padding:5px 15px;border-radius:4px;font-size:.8rem;font-weight:700;cursor:pointer}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.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;line-clamp:2;-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}.install-instructions{display:flex;flex-direction:column;gap:15px;text-align:left}.inst-step{background:#ffffff0d;padding:12px;border-radius:8px;border-left:3px solid var(--accent)}.inst-step strong{display:block;margin-bottom:5px;color:var(--accent)}.inst-step p{margin:0;font-size:.9rem;line-height:1.4}.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)}}.npc-section-header{display:flex;justify-content:space-between;align-items:center;margin-top:32px;margin-bottom:16px;padding:0 4px}.npc-card{border-left:3px solid var(--accent)!important}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.jogador-card{animation:fadeInScale .3s ease-out}.inventory-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05)}.inventory-row:last-child{border-bottom:none}.col-flex-1{flex:1;min-width:50px}.col-flex-2{flex:2;min-width:100px}.hide-arrows::-webkit-outer-spin-button,.hide-arrows::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.hide-arrows{-moz-appearance:textfield;appearance:textfield}.textarea-item{resize:vertical;min-height:42px;line-height:1.4;font-family:inherit}.accordion-item{border:1px solid rgba(255,255,255,.05);border-radius:8px;transition:all .3s ease}.accordion-item:hover{border-color:#ffffff26}.accordion-header{-webkit-user-select:none;user-select:none}.accordion-header:hover{background-color:#ffffff14!important}.accordion-body{animation:slideDown .3s ease-out}.dice-canvas-overlay{position:fixed;inset:0;background:radial-gradient(circle at center,#1e1e1ef2,#0a0a0af2);z-index:99999;display:flex;flex-direction:column;justify-content:space-between;align-items:center;padding:40px 20px;overflow:hidden;-webkit-user-select:none;user-select:none}.dice-canvas-header{text-align:center;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5);animation:fadeInDown .5s ease-out}.dice-canvas-header h2{font-family:Cinzel,serif;font-size:2rem;color:#f44;margin-bottom:5px}.dice-pool-container{display:flex;flex-wrap:wrap;gap:30px;justify-content:center;align-items:center;flex:1;max-width:800px;align-content:center;perspective:1000px}.dice-cube{position:relative;width:60px;height:60px;transform-style:preserve-3d;transition:transform .5s;cursor:pointer}.dice-cube.rolling{animation:spin3D .8s infinite linear,bounceDice .5s infinite alternate ease-in-out;pointer-events:none}@keyframes spin3D{0%{transform:rotateX(0) rotateY(0) rotate(0)}to{transform:rotateX(360deg) rotateY(720deg) rotate(360deg)}}@keyframes bounceDice{0%{transform:translateY(0)}to{transform:translateY(-40px)}}.dice-face{position:absolute;width:100%;height:100%;background:radial-gradient(circle at center,#c00,#600);border:1px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:900;color:#fff;text-shadow:0 0 5px rgba(0,0,0,.8);box-shadow:inset 0 0 15px #000c;backface-visibility:inherit;clip-path:polygon(50% 0%,100% 25%,50% 100%,0% 25%)}.front{transform:translateZ(15px) rotateX(20deg)}.back{transform:rotateY(180deg) translateZ(15px) rotateX(20deg)}.right{transform:rotateY(90deg) translateZ(15px) rotateX(20deg)}.left{transform:rotateY(-90deg) translateZ(15px) rotateX(20deg)}.top{transform:rotateY(45deg) translateZ(15px) rotateX(20deg)}.bottom{transform:rotateY(-45deg) translateZ(15px) rotateX(20deg)}.roll-result-banner{background:#000000d9;padding:15px 40px;border-radius:12px;animation:popIn .5s cubic-bezier(.175,.885,.32,1.275)}.roll-result-banner.success{border:2px solid #44ff44;box-shadow:0 0 30px #00ff004d}.roll-result-banner.success h3{color:#fff;text-shadow:0 0 15px #44ff44}.roll-result-banner.failure{border:2px solid #ff4444;box-shadow:0 0 30px #ff000080}.roll-result-banner.failure h3{color:#f44;text-shadow:0 0 15px #ff0000}.dice-canvas-actions{animation:fadeInUp .5s ease-out}.roll-btn{font-size:1.5rem;padding:15px 40px;border-radius:30px;background:linear-gradient(135deg,#a00000,#500000);border:2px solid #ff4a4a;box-shadow:0 0 20px #ff00004d;text-transform:uppercase;letter-spacing:2px;cursor:pointer}.roll-btn:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 0 30px #f009}.jogadores-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.char-card{background:linear-gradient(135deg,#140c0ff2,#1e1216f2);border:1px solid rgba(139,0,0,.3);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s ease;position:relative}.char-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,#8B0000,#C41E3A,#8B0000,transparent);opacity:0;transition:opacity .3s}.char-card:hover{transform:translateY(-4px);border-color:#c41e3a80;box-shadow:0 12px 32px #8b00004d,0 0 40px #8b00001a}.char-card:hover:before{opacity:1}.char-card-header{display:flex;gap:14px;padding:16px 16px 12px;align-items:center}.char-card-avatar{width:64px;height:64px;border-radius:50%;overflow:hidden;border:2px solid rgba(139,0,0,.5);flex-shrink:0;position:relative;box-shadow:0 0 16px #8b00004d}.char-card-avatar img{width:100%;height:100%;object-fit:cover;display:block}.char-card-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2a1520,#1a0a10);color:#c41e3a;font-size:24px;font-weight:700;font-family:Cinzel Decorative,serif}.char-card-identity{display:flex;flex-direction:column;gap:2px;min-width:0}.char-card-name{font-family:Cinzel Decorative,serif;font-size:1rem;color:#f5ede4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0;line-height:1.2}.char-card-clan{font-size:.75rem;color:#c41e3a;text-transform:uppercase;letter-spacing:.1em;font-weight:600}.char-card-player{font-size:.7rem;color:#a8988099;font-style:italic}.char-card-stats{padding:0 16px 12px;display:grid;grid-template-columns:1fr 1fr;gap:8px}.char-card-stat{display:flex;flex-direction:column;gap:3px}.char-card-stat-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.15em;color:#a8988080}.char-card-stat-value{font-size:.85rem;color:#e8ddd0;font-weight:600}.char-card-blood-bar{width:100%;height:6px;background:#ffffff0f;border-radius:3px;overflow:hidden}.char-card-blood-fill{height:100%;background:linear-gradient(90deg,#4a0010,#c41e3a);border-radius:3px;transition:width .5s ease;box-shadow:0 0 8px #c41e3a80}.char-card-blood-text{font-size:.7rem!important}.char-card-health-dots{display:flex;gap:4px;flex-wrap:wrap}.health-dot{width:10px;height:10px;border-radius:50%;border:1px solid rgba(255,255,255,.15);transition:all .3s}.health-dot.ok{background:#32c8324d;border-color:#32c83280}.health-dot.contusao{background:#c8c83266;border-color:#c8c83299}.health-dot.letal{background:#c8501e80;border-color:#c8501eb3}.health-dot.agravado{background:#c81e1e99;border-color:#c81e1ecc;box-shadow:0 0 4px #c81e1e80}.char-card-roll{padding:6px 16px;font-size:.75rem;text-align:center}.char-card-roll.roll-success{background:#32c8321a;color:#8f8;border-top:1px solid rgba(50,200,50,.2)}.char-card-roll.roll-fail{background:#c832321a;color:#f88;border-top:1px solid rgba(200,50,50,.2)}.char-card-roll.roll-pending{background:#c8c8321a;color:#ffa;border-top:1px solid rgba(200,200,50,.2)}.char-card-actions{display:flex;gap:0;border-top:1px solid rgba(139,0,0,.2)}.char-card-btn{flex:1;padding:10px 6px;border:none;background:transparent;color:#a89880b3;font-size:.72rem;font-weight:600;cursor:pointer;transition:all .2s;border-right:1px solid rgba(139,0,0,.15);display:flex;flex-direction:column;align-items:center;gap:2px}.char-card-btn:last-child{border-right:none}.char-card-btn:hover{background:#8b000026;color:#f5ede4}.btn-xp-mini{color:#ffc832b3}.btn-xp-mini:hover{color:gold;background:#ffc8321a}.btn-roll-mini{color:#6496ffb3}.btn-roll-mini:hover{color:#8af;background:#6496ff1a}.btn-npc-mini{color:#c41e3ab3}.btn-npc-mini:hover{color:#c41e3a;background:#c41e3a1a}.btn-remove-mini{color:#ff505080;flex:.6}.btn-remove-mini:hover{background:#c81e1e33;color:#f66}.char-card-empty{padding:24px 16px;display:flex;flex-direction:column;align-items:center;gap:8px;color:#a8988066;text-align:center}.char-card-empty p{margin:0;color:#a8988099}.char-card-empty span{font-size:.75rem}@media(max-width:600px){.jogadores-grid{grid-template-columns:1fr}.char-card-stats{grid-template-columns:1fr 1fr}}.char-card-toggle{background:none;border:1px solid rgba(139,0,0,.3);color:#c41e3ab3;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:.65rem;display:flex;align-items:center;justify-content:center;transition:all .3s;flex-shrink:0;margin-left:auto}.char-card-toggle:hover{background:#8b000033;border-color:#c41e3a99;color:#c41e3a}.char-card.expanded .char-card-toggle{background:#8b000026;color:#c41e3a}.xp-history-container{max-height:250px;overflow-y:auto;padding-right:8px;display:flex;flex-direction:column;gap:12px}.xp-history-container::-webkit-scrollbar{width:4px}.xp-history-container::-webkit-scrollbar-track{background:#ffffff0d}.xp-history-container::-webkit-scrollbar-thumb{background:var(--accent);border-radius:10px}.xp-history-item{background:#ffffff08;border-left:3px solid var(--accent);padding:10px 14px;border-radius:4px 10px 10px 4px;transition:all .2s}.xp-history-item:hover{background:#ffffff0d;transform:translate(2px)}.xp-history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.xp-amount-negative{color:#ff4d4d;font-weight:700;font-size:.95rem;text-shadow:0 0 10px rgba(255,77,77,.3)}.xp-date{color:var(--text-muted);font-size:.75rem;font-weight:500}.xp-reason{color:var(--text-primary);font-size:.9rem;line-height:1.4}
