*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:#0a0a1a;color:#e0d8c8;-webkit-font-smoothing:antialiased}.app{width:100%;height:100vh;position:relative;overflow:hidden}.setup-screen{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1.5rem;animation:fadeIn .5s ease;background:radial-gradient(ellipse at center,#0a0a1ad9,#0a0a1aa6 60%,#0a0a1a4d)}.setup-header{text-align:center;margin-bottom:1rem}.title{font-size:3.5rem;font-weight:800;background:linear-gradient(135deg,#f7d774,#e8a838,#f7d774);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none;letter-spacing:-1px}.subtitle{font-size:1.1rem;color:#8a8598;margin-top:.5rem}.character-list{display:flex;flex-direction:column;gap:.5rem;width:100%;max-width:500px;max-height:50vh;overflow-y:auto;padding:.5rem}.char-row-wrapper{display:grid;grid-template-rows:1fr;opacity:1;transition:grid-template-rows .4s cubic-bezier(.23,1,.32,1),opacity .3s ease}.char-row-wrapper.entering{grid-template-rows:0fr;opacity:0}.char-row-wrapper.leaving{grid-template-rows:0fr;opacity:0;pointer-events:none}.character-row{display:flex;align-items:center;gap:.75rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:.5rem .75rem;transition:background .2s;overflow:hidden;min-height:0;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.character-row:hover{background:#ffffff1a}.color-swatch{width:24px;height:24px;border-radius:50%;flex-shrink:0;box-shadow:0 0 8px #0000004d}.name-input{flex:1;background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.15);color:#e0d8c8;font-size:1rem;padding:.4rem 0;outline:none;transition:border-color .2s}.name-input:focus{border-bottom-color:#f7d774}.name-input::placeholder{color:#fff3}.bonus-group{display:flex;align-items:center;gap:2px;color:#8a8598;font-size:.9rem}.bonus-label{color:#8a8598}.bonus-input{width:3rem;background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.15);color:#e0d8c8;font-size:.9rem;text-align:center;padding:.3rem 0;outline:none}.bonus-input:focus{border-bottom-color:#f7d774}.remove-btn{background:none;border:none;color:#fff3;font-size:1.3rem;cursor:pointer;padding:0 .3rem;transition:color .2s;line-height:1}.remove-btn:hover{color:#e74c3c}.add-btn{background:#ffffff0d;border:1px dashed rgba(255,255,255,.15);color:#8a8598;font-size:.95rem;padding:.6rem 1.5rem;border-radius:10px;cursor:pointer;transition:all .2s;width:100%;max-width:500px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.add-btn:hover{background:#ffffff14;color:#e0d8c8}.roll-btn{background:linear-gradient(135deg,#e8a838,#f7d774);color:#1a1a2e;font-size:1.4rem;font-weight:700;padding:1rem 3rem;border:none;border-radius:14px;cursor:pointer;margin-top:1rem;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 20px #f7d7744d;letter-spacing:.5px}.roll-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 6px 30px #f7d77480}.roll-btn:active:not(:disabled){transform:scale(.98)}.roll-btn:disabled{opacity:.4;cursor:not-allowed}.hint{font-size:.85rem;color:#5a5568}.roll-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;justify-content:flex-end;pointer-events:none}.name-tags{width:280px;flex-shrink:0;padding:1.5rem 1rem;display:flex;flex-direction:column;gap:.5rem;background:#00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-left:1px solid rgba(255,255,255,.06);animation:slideInRight .6s cubic-bezier(.23,1,.32,1);overflow-y:auto;pointer-events:auto}.tags-title{font-size:1.1rem;font-weight:600;color:#8a8598;text-transform:uppercase;letter-spacing:2px;margin-bottom:.5rem;text-align:center}.tags-container{display:flex;flex-direction:column;gap:6px}.name-tag{display:flex;align-items:center;gap:.6rem;padding:.6rem .75rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:8px;position:relative;will-change:transform}.name-tag.revealed{background:#ffffff14;border-color:var(--tag-color, rgba(255, 255, 255, .15))}.tag-color{width:16px;height:16px;border-radius:50%;flex-shrink:0}.tag-name{flex:1;font-size:.95rem;font-weight:500;color:#e0d8c8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tag-result{display:flex;align-items:center;gap:.25rem;font-size:.85rem;animation:resultFade .3s ease}.tag-roll{color:#f7d774;font-weight:600}.tag-bonus{color:#8a8598}.tag-equals{color:#5a5568;margin:0 .1rem}.tag-total{font-size:1.05rem;font-weight:700;color:#fff;background:#f7d77426;padding:.1rem .4rem;border-radius:4px}.rolling-label{text-align:center;font-size:1.2rem;font-weight:600;color:#f7d774;text-shadow:0 0 20px rgba(247,215,116,.5);animation:pulse 1.5s ease-in-out infinite;margin-top:.5rem}.roll-again-btn{margin-top:1.5rem;background:linear-gradient(135deg,#e8a838,#f7d774);color:#1a1a2e;font-size:1rem;font-weight:700;padding:.7rem 1.5rem;border:none;border-radius:10px;cursor:pointer;transition:transform .15s;animation:fadeIn .5s ease}.roll-again-btn:hover{transform:scale(1.05)}.flyaway{position:fixed;z-index:100;pointer-events:none;transition:all .7s cubic-bezier(.23,1,.32,1);opacity:0}.flyaway-value{display:inline-block;font-size:1.6rem;font-weight:800;color:#fff;background:var(--fly-color, #f7d774);padding:.2rem .6rem;border-radius:8px;box-shadow:0 4px 15px #0006,0 0 20px var(--fly-color);text-shadow:0 1px 3px rgba(0,0,0,.4)}.fanfare{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:50;overflow:hidden}.confetti{position:absolute;top:-10px;border-radius:2px;opacity:0;animation:confettiFall linear forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes resultFade{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes confettiFall{0%{opacity:1;transform:translateY(0) rotate(0)}to{opacity:0;transform:translateY(100vh) rotate(720deg)}}
