:root{--bg-color:#0f1015;--panel-bg:#161821d9;--border-color:#d4af3740;--border-focus:#d4af37;--text-primary:#f0f0f5;--text-secondary:#a0a5b5;--gold-gradient:linear-gradient(135deg, #b58d3d 0%, #e6c673 50%, #b58d3d 100%);--accent-color:#d4af37;--danger-color:#e25858;--success-color:#55c57a;--shadow:0 8px 32px 0 #00000080;--glass-blur:blur(8px)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-primary);background-image:radial-gradient(circle at 10% 20%,#d4af370d 0%,#0000 40%),radial-gradient(circle at 90% 80%,#6200ea08 0%,#0000 40%);height:100vh;font-family:Noto Sans KR,sans-serif;overflow:hidden}.hidden{display:none!important}.fantasy-title{letter-spacing:3px;background:var(--gold-gradient);-webkit-text-fill-color:transparent;text-shadow:0 4px 10px #0009;-webkit-background-clip:text;font-family:Cinzel,serif;font-weight:900}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#0003}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent-color)}#login-screen{z-index:10;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:absolute;top:0;left:0}.login-container{background:var(--panel-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--border-color);width:90%;max-width:680px;box-shadow:var(--shadow);text-align:center;border-radius:12px;padding:3rem;animation:.8s ease-out fadeIn}.login-container h1{margin-bottom:.5rem;font-size:3rem}.subtitle{color:var(--text-secondary);margin-bottom:2.5rem;font-size:1rem}.player-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2rem;display:grid}.player-btn{border:1px solid var(--border-color);cursor:pointer;background:#ffffff08;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:1.5rem 1rem;transition:all .3s cubic-bezier(.25,.8,.25,1);display:flex}.player-btn:hover{border-color:var(--accent-color);background:#d4af371a;transform:translateY(-4px);box-shadow:0 6px 20px #d4af3726}.player-btn .avatar-icon{color:var(--accent-color);font-size:2rem;transition:transform .3s}.player-btn:hover .avatar-icon{transform:scale(1.15)rotate(5deg)}.player-name{color:var(--text-primary);font-size:1.1rem;font-weight:500}.divider{color:var(--text-secondary);align-items:center;margin:1.5rem 0;font-size:.9rem;display:flex}.divider:before,.divider:after{content:"";background:#ffffff1a;flex:1;height:1px;margin:0 1rem}.master-btn{border:1px solid var(--danger-color);cursor:pointer;background:linear-gradient(135deg,#d4af371a 0%,#e258581a 100%);border-radius:8px;justify-content:center;align-items:center;gap:1rem;width:100%;padding:1.2rem;transition:all .3s;display:flex}.master-btn:hover{background:linear-gradient(135deg,#d4af3733 0%,#e2585833 100%);border-color:#ff8b8b;transform:translateY(-2px);box-shadow:0 4px 15px #e2585833}.master-btn .avatar-icon{color:var(--danger-color);font-size:1.8rem}.master-btn .player-name{letter-spacing:1px;font-family:Cinzel,serif;font-weight:700}#main-screen{flex-direction:column;width:100vw;height:100vh;display:flex}.game-header{border-bottom:1px solid var(--border-color);background:#0f1015f2;justify-content:space-between;align-items:center;height:60px;padding:0 1.5rem;display:flex;box-shadow:0 4px 10px #0000004d}.game-header .logo{color:var(--accent-color);margin-right:1.5rem;font-family:Cinzel,serif;font-size:1.3rem;font-weight:700}.game-header .logo i{margin-right:.3rem}.session-info{color:var(--text-secondary);border-left:1px solid #ffffff1a;padding-left:1.5rem;font-size:.9rem}.header-right{align-items:center;gap:1.5rem;display:flex}.user-badge{border:1px solid var(--border-color);color:var(--accent-color);background:#d4af3726;border-radius:20px;padding:.4rem .8rem;font-size:.9rem;font-weight:500}.header-action-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:1px solid #fff3;border-radius:4px;padding:.4rem .8rem;font-size:.85rem;transition:all .2s}.header-action-btn:hover{border-color:var(--danger-color);color:var(--text-primary);background:#de58581a}.game-grid{flex:1;grid-template-columns:1fr 380px;height:calc(100vh - 60px);display:grid;overflow:hidden}.left-panel{grid-template-rows:auto 1fr;grid-template-columns:1.6fr 1fr;gap:1rem;height:100%;padding:1rem;display:grid;overflow:hidden}.right-panel{border-left:1px solid var(--border-color);background:#0f101599;flex-direction:column;padding:1rem;display:flex;overflow:hidden}.panel{background:var(--panel-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--border-color);box-shadow:var(--shadow);border-radius:8px;flex-direction:column;display:flex;overflow:hidden}.panel-header{background:#0003;border-bottom:1px solid #d4af3726;justify-content:space-between;align-items:center;padding:.8rem 1.2rem;display:flex}.panel-header h2{letter-spacing:.5px;color:var(--accent-color);align-items:center;gap:.5rem;font-family:Cinzel,serif;font-size:1.1rem;font-weight:700;display:flex}.panel-content{flex:1;padding:1rem;overflow-y:auto}.shared-photo-panel{flex-direction:column;grid-area:1/1/3/2;height:100%;display:flex}.dice-panel{flex-direction:column;grid-area:1/2/2/3;display:flex}.character-sheet-panel{flex-direction:column;grid-area:2/2/3/3;height:100%;display:flex;overflow:hidden}.photo-controls{gap:.5rem;max-width:600px;display:flex}.photo-controls input{border:1px solid var(--border-color);color:var(--text-primary);background:#0000004d;border-radius:4px;flex:1;padding:.3rem .6rem;font-size:.85rem}.photo-controls input:focus{border-color:var(--accent-color);outline:none;box-shadow:0 0 5px #d4af374d}.btn{cursor:pointer;border:none;border-radius:4px;padding:.3rem .8rem;font-size:.85rem;font-weight:500;transition:all .2s}.btn-primary{background:var(--gold-gradient);color:#12131a}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 2px 8px #d4af3766}.photo-viewport{background:#0006;justify-content:center;align-items:center;display:flex;position:relative}.image-container{justify-content:center;align-items:center;width:100%;height:100%;display:flex;overflow:hidden}.image-container img{object-fit:contain;border-radius:4px;max-width:100%;max-height:100%;animation:.5s ease-out fadeIn;box-shadow:0 4px 10px #00000080}.placeholder-text{color:var(--text-secondary);text-align:center;flex-direction:column;align-items:center;gap:.8rem;font-size:.9rem;display:flex}.placeholder-text i{opacity:.3;font-size:2.5rem}.dice-panel{flex-direction:column;display:flex}.dice-grid{grid-template-columns:repeat(3,1fr);align-content:center;gap:.75rem;display:grid}.dice-btn{border:1px solid var(--border-color);cursor:pointer;background:#ffffff05;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;gap:.4rem;padding:.8rem .5rem;transition:all .2s;display:flex;position:relative}.dice-btn:hover{border-color:var(--accent-color);background:#d4af3714;transform:scale(1.05)}.dice-shape{color:var(--accent-color);justify-content:center;align-items:center;height:35px;font-size:1.8rem;display:flex}.dice-label{color:var(--text-secondary);font-family:Cinzel,serif;font-size:.85rem;font-weight:700}.dice-btn:hover .dice-label{color:var(--text-primary)}.dice-footer{color:var(--text-secondary);text-align:center;background:#0000001a;border-top:1px solid #ffffff0d;padding:.5rem 1rem;font-size:.75rem}.character-sheet-panel{flex-direction:column;flex:1;display:flex}.sheet-controls{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.9rem;display:flex}.char-select-dropdown{border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;background:#1a1c24;border-radius:4px;padding:.3rem .8rem;font-weight:500}.char-select-dropdown:focus{border-color:var(--accent-color);outline:none}.save-status{color:var(--text-secondary);background:#ffffff0d;border-radius:12px;align-items:center;gap:.3rem;padding:.2rem .6rem;font-size:.8rem;display:flex}.save-status.saving{color:var(--accent-color)}.save-status.saved{color:var(--success-color)}.character-sheet-form{overflow-y:auto}.char-info-header{background:#00000026;border:1px solid #d4af371a;border-radius:6px;grid-template-columns:repeat(2,1fr);gap:.8rem;margin-bottom:.8rem;padding:.8rem;display:grid}.form-group{flex-direction:column;gap:.3rem;display:flex}.form-group label{text-transform:uppercase;color:var(--accent-color);letter-spacing:.5px;font-size:.75rem;font-weight:500}.sheet-input{border:1px solid #ffffff1a;border-bottom:2px solid var(--border-color);color:var(--text-primary);background:#00000040;border-radius:4px 4px 0 0;padding:.5rem;font-size:.95rem;transition:all .2s}.sheet-input:focus{border-bottom-color:var(--accent-color);background:#0006;outline:none}.char-sheet-grid{flex-direction:column;gap:1rem;display:flex}.sheet-col{background:#0000001a;border:1px solid #ffffff08;border-radius:6px;flex-direction:column;gap:1rem;padding:1rem;display:flex}.sheet-col h3{color:var(--accent-color);border-bottom:1px solid #d4af3726;margin-bottom:.3rem;padding-bottom:.4rem;font-family:Cinzel,serif;font-size:.95rem}.ability-scores-container{grid-template-columns:repeat(3,1fr);gap:.5rem;display:grid}.ability-card{border:1px solid var(--border-color);background:#ffffff05;border-radius:6px;flex-direction:column;align-items:center;padding:.5rem .2rem;display:flex;position:relative}.ability-label{color:var(--text-secondary);margin-bottom:.2rem;font-size:.75rem;font-weight:500}.stat-input{color:var(--text-primary);text-align:center;background:0 0;border:none;width:45px;font-size:1.3rem;font-weight:700}.stat-input:focus{color:var(--accent-color);outline:none}.stat-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.stat-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.modifier-box{border:1px solid var(--border-color);width:32px;height:32px;color:var(--accent-color);background:#d4af3726;border-radius:50%;justify-content:center;align-items:center;margin-top:.3rem;font-size:.85rem;font-weight:700;display:flex}.skills-box{margin-top:.5rem}.skills-list{flex-direction:column;gap:.4rem;max-height:280px;padding-right:.3rem;display:flex;overflow-y:auto}.skills-list label{color:var(--text-secondary);cursor:pointer;border-radius:3px;align-items:center;gap:.5rem;padding:.2rem;font-size:.8rem;transition:background .2s;display:flex}.skills-list label:hover{color:var(--text-primary);background:#ffffff08}.skills-list input[type=checkbox]{accent-color:var(--accent-color);cursor:pointer}.combat-stats-row,.combat-stats-row-secondary{grid-template-columns:repeat(3,1fr);gap:.5rem;display:grid}.combat-stats-row-secondary{grid-template-columns:1fr 1.5fr}.combat-card{background:#0003;border:1px solid #ffffff0d;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;gap:.3rem;padding:.6rem;display:flex}.ac-card{border-color:var(--border-color)}.current-hp-card{border-color:var(--danger-color);background:#e258580d}.combat-card-label{color:var(--text-secondary);text-align:center;font-size:.75rem}.combat-stat-input{color:var(--text-primary);text-align:center;background:0 0;border:none;width:100%;font-size:1.4rem;font-weight:700}.combat-stat-input:focus{color:var(--accent-color);outline:none}.death-saves-checks{flex-direction:column;gap:.2rem;width:100%;display:flex}.save-row{color:var(--text-secondary);justify-content:space-between;align-items:center;width:100%;padding:0 .2rem;font-size:.7rem;display:flex}.save-row input[type=checkbox]{accent-color:var(--accent-color);cursor:pointer}.save-row:first-child input[type=checkbox]{accent-color:var(--success-color)}.save-row:last-child input[type=checkbox]{accent-color:var(--danger-color)}.textarea-box{flex-direction:column;flex:1;gap:.4rem;display:flex}.textarea-box textarea,.form-group-text textarea{width:100%;color:var(--text-primary);resize:none;background:#00000040;border:1px solid #ffffff0d;border-radius:4px;flex:1;min-height:80px;padding:.5rem;font-family:inherit;font-size:.85rem;line-height:1.4}.textarea-box textarea:focus,.form-group-text textarea:focus{border-color:var(--accent-color);background:#0006;outline:none}.personality-grid{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.form-group-text{flex-direction:column;gap:.2rem;display:flex}.form-group-text label{color:var(--accent-color);font-size:.75rem;font-weight:500}.chat-panel{flex-direction:column;height:100%;display:flex}.chat-messages{background:#0003;flex-direction:column;flex:1;gap:.8rem;padding:1rem;display:flex}.message{flex-direction:column;max-width:85%;animation:.3s ease-out messageSlideIn;display:flex}.message-header{align-items:baseline;gap:.5rem;margin-bottom:.2rem;font-size:.75rem;display:flex}.message-sender{color:var(--accent-color);font-weight:700}.message-time{color:#ffffff4d}.message-content{color:var(--text-primary);word-break:break-all;background:#ffffff0d;border:1px solid #ffffff08;border-radius:0 12px 12px;padding:.6rem .8rem;font-size:.9rem;line-height:1.4}.message.self{align-self:flex-end}.message.self .message-sender{color:#ffdf00}.message.self .message-content{background:#d4af371a;border-color:#d4af3726;border-radius:12px 0 12px 12px}.message.system{align-self:center;max-width:100%}.message.system .message-content{color:var(--text-secondary);text-align:center;background:#ffffff05;border:1px dashed #ffffff1a;border-radius:20px;padding:.4rem 1rem;font-size:.8rem}.message.dice-roll{align-self:center;width:100%;max-width:90%}.message.dice-roll .message-content{border:1px solid var(--border-color);color:var(--text-primary);background:linear-gradient(135deg,#d4af3714 0%,#e2585814 100%);border-radius:8px;justify-content:space-between;align-items:center;gap:1rem;padding:.6rem 1rem;font-size:.85rem;display:flex}.dice-roll-details{flex-direction:column;display:flex}.dice-roll-name{color:var(--accent-color);font-size:.9rem;font-weight:700}.dice-roll-formula{color:var(--text-secondary);margin-top:.15rem;font-size:.75rem}.dice-roll-result{color:#ffdf00;text-shadow:0 0 10px #d4af3780;align-items:center;gap:.5rem;font-family:Cinzel,serif;font-size:1.8rem;font-weight:900;display:flex}.dice-roll-result i{color:var(--accent-color);font-size:1.2rem}.chat-input-area{border-top:1px solid #ffffff0d;gap:.5rem;padding:.8rem 0;display:flex}#chat-input-field{border:1px solid var(--border-color);color:var(--text-primary);background:#0000004d;border-radius:4px;flex:1;padding:.6rem .8rem;font-size:.9rem}#chat-input-field:focus{border-color:var(--accent-color);outline:none;box-shadow:0 0 5px #d4af374d}#chat-send-btn{justify-content:center;align-items:center;width:45px;height:38px;padding:0;font-size:1rem;display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.dice-shake{animation:.6s ease-out diceRollAnimation}@keyframes diceRollAnimation{0%{transform:scale(1)rotate(0)}20%{transform:scale(1.2)rotate(-20deg)}45%{transform:scale(1.2)rotate(45deg)}70%{transform:scale(1.1)rotate(-45deg)}to{transform:scale(1)rotate(360deg)}}@media (width<=1200px){.game-grid{grid-template-rows:1fr 300px;grid-template-columns:1fr;height:calc(100vh - 60px)}.right-panel{border-left:none;border-top:1px solid var(--border-color);height:300px}.char-sheet-grid{grid-template-columns:1fr 1fr}}@media (width<=768px){.login-container{padding:1.5rem}.player-grid{grid-template-columns:repeat(2,1fr)}.char-info-header{grid-template-columns:1fr 1fr}.char-sheet-grid{grid-template-columns:1fr}}
