*{box-sizing:border-box}:root{--color-background: #1a1a2e;--color-background-secondary: #16213e;--color-highlight: #e94560;--color-button: #e94560;--color-button-hover: #d63850;--color-text: #fff;--color-text-muted: #8b8b8b;--color-border: #0f4c75;--color-success: #4caf50;--color-error: #f44336;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color:var(--color-text);background-color:var(--color-background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}a{color:var(--color-highlight);text-decoration:none}a:hover{text-decoration:underline}button,input{font-family:inherit}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-background);padding:1rem}.login-card{background:var(--color-background-secondary);border-radius:16px;padding:2.5rem;width:100%;max-width:400px}.login-title{font-size:2.5rem;font-weight:700;color:var(--color-highlight);text-align:center;margin:0 0 .5rem}.login-subtitle{font-size:1rem;color:#8b8b8b;text-align:center;margin:0 0 2rem}.login-input{width:100%;padding:1rem;background:var(--color-background);border:none;border-radius:12px;color:var(--color-text);font-size:1rem;margin-bottom:1rem;box-sizing:border-box}.login-input::placeholder{color:#666}.login-input:focus{outline:2px solid var(--color-highlight)}.login-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem;cursor:pointer}.login-select option{background:var(--color-background);color:var(--color-text)}.timezone-hint{color:#666;font-size:.75rem;text-align:center;margin:-.5rem 0 1rem}.login-button{width:100%;padding:1rem;background:var(--color-button);border:none;border-radius:12px;color:var(--color-text);font-size:1.125rem;font-weight:600;cursor:pointer;margin-top:.5rem;transition:opacity .2s}.login-button:hover{opacity:.9}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-error{color:#f44336;text-align:center;margin:0 0 1rem;font-size:.875rem}.login-switch{width:100%;background:none;border:none;color:#0f4c75;cursor:pointer;margin-top:1.5rem;font-size:.875rem}.login-switch:hover{text-decoration:underline}.class-selection{margin-bottom:1rem}.class-label{display:block;font-size:.875rem;color:#8b8b8b;margin-bottom:.75rem;text-align:center}.class-options{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.class-option{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem .5rem;background:var(--color-background);border:2px solid transparent;border-radius:10px;cursor:pointer;transition:all .2s}.class-option:hover{border-color:#3a3a5c}.class-option.selected{border-color:var(--color-highlight);background:#e945601a}.class-icon{font-size:1.5rem}.class-name{font-size:.9rem;font-weight:600;color:#fff}.class-desc{font-size:.7rem;color:#8b8b8b;text-align:center}@media(min-width:500px){.login-card:has(.class-selection){max-width:450px}}@media(max-width:400px){.class-options{grid-template-columns:1fr}.class-option{flex-direction:row;gap:.75rem;text-align:left;padding:.75rem 1rem}.class-icon{font-size:1.75rem}.class-desc{text-align:left}}.skills-panel{background:#1a1a2e;border-radius:8px;padding:1rem;color:#fff}.skills-panel.loading{text-align:center;padding:2rem;color:#888}.skills-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.skills-header h3{margin:0;color:gold}.auto-learn-btn{background:#4caf50;border:none;color:#fff;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.85rem}.auto-learn-btn:hover{background:#45a049}.skills-error{background:#f44;color:#fff;padding:.5rem;border-radius:4px;margin-bottom:1rem;text-align:center}.skills-tabs{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:2px solid #333;padding-bottom:.5rem}.skills-tabs .tab{background:transparent;border:none;color:#888;padding:.5rem 1rem;cursor:pointer;font-size:1rem;border-radius:4px 4px 0 0;transition:all .2s}.skills-tabs .tab:hover{color:#fff;background:#ffffff1a}.skills-tabs .tab.active{color:gold;background:#ffd7001a;border-bottom:2px solid #ffd700;margin-bottom:-2px}.skills-content{max-height:400px;overflow-y:auto}.skills-list{display:flex;flex-direction:column;gap:.75rem}.no-skills{text-align:center;color:#888;padding:2rem}.skill-card{background:#252540;border-radius:6px;padding:.75rem;border-left:3px solid #666}.skill-card.passive{border-left-color:#4caf50}.skill-card.active{border-left-color:#2196f3}.skill-card.inactive{opacity:.6}.skill-card.available{border-left-color:gold}.skill-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.skill-name{font-weight:700;color:#fff}.skill-level{color:#888;font-size:.85rem}.toggle-btn{padding:.25rem .75rem;border:none;border-radius:4px;cursor:pointer;font-size:.75rem;font-weight:700}.toggle-btn.on{background:#4caf50;color:#fff}.toggle-btn.off{background:#666;color:#ccc}.skill-description{margin:0 0 .5rem;color:#aaa;font-size:.9rem;line-height:1.4}.skill-effect{background:#0003;padding:.5rem;border-radius:4px;font-size:.85rem;color:#4caf50;margin-bottom:.5rem}.skill-costs{display:flex;gap:1rem;font-size:.8rem;color:#888}.skill-costs span{background:#ffffff1a;padding:.25rem .5rem;border-radius:3px}.learn-btn{width:100%;background:gold;color:#1a1a2e;border:none;padding:.5rem;border-radius:4px;cursor:pointer;font-weight:700;margin-top:.5rem}.learn-btn:hover{background:#ffed4a}.skills-content::-webkit-scrollbar{width:8px}.skills-content::-webkit-scrollbar-track{background:#1a1a2e}.skills-content::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.skills-content::-webkit-scrollbar-thumb:hover{background:#555}.chat-panel{display:flex;flex-direction:column;background:#16213e;border-radius:12px;height:400px;overflow:hidden}.chat-header{padding:.75rem 1rem;background:#1a1a2e;border-bottom:1px solid #2a2a4e}.chat-header h3{margin:0;font-size:1rem;color:#e94560}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.chat-loading,.chat-empty{text-align:center;color:#888;padding:2rem}.chat-message{max-width:85%;padding:.5rem .75rem;background:#1a1a2e;border-radius:8px;word-wrap:break-word}.chat-message.own-message{align-self:flex-end;background:#2a3f5f}.chat-message.system-message{align-self:center;background:transparent;color:#888;font-size:.85rem;font-style:italic}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem;gap:.5rem}.message-author{font-weight:600;font-size:.85rem;color:#e94560}.own-message .message-author{color:#4fc3f7}.message-time{font-size:.7rem;color:#666}.message-content{font-size:.9rem;color:#fff;line-height:1.4}.message-content em{color:#aaa}.chat-input-area{display:flex;gap:.5rem;padding:.75rem;background:#1a1a2e;border-top:1px solid #2a2a4e}.chat-input-area input{flex:1;padding:.5rem .75rem;background:#0f0f23;border:1px solid #2a2a4e;border-radius:6px;color:#fff;font-size:.9rem}.chat-input-area input:focus{outline:none;border-color:#e94560}.chat-input-area input::placeholder{color:#666}.chat-input-area button{padding:.5rem 1rem;background:#e94560;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:opacity .2s}.chat-input-area button:hover:not(:disabled){opacity:.9}.chat-input-area button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.chat-panel{height:300px}.chat-message{max-width:90%}}.room-grid-container{position:relative;padding:1rem}.room-grid-empty{display:flex;align-items:center;justify-content:center;min-height:200px;color:#8b8b8b}.room-grid{display:grid;gap:8px;position:relative;z-index:2}.room-cell{aspect-ratio:1;min-width:60px;min-height:60px;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;cursor:default;transition:all .2s;border:2px solid transparent;background:#1a1a2e}.room-cell.empty{background:transparent;border:none}.room-cell.entrance{background:#2e7d32;border-color:#4caf50}.room-cell.combat{background:#b71c1c;border-color:#f44336}.room-cell.boss{background:#4a148c;border-color:#9c27b0;animation:bossPulse 2s ease-in-out infinite}@keyframes bossPulse{0%,to{box-shadow:0 0 10px #9c27b080}50%{box-shadow:0 0 20px #9c27b0cc}}.room-cell.treasure{background:#f57f17;border-color:#ffca28}.room-cell.trap{background:#e65100;border-color:#ff9800}.room-cell.rest{background:#0d47a1;border-color:#2196f3}.room-cell.shop{background:#1b5e20;border-color:#66bb6a}.room-cell.unknown{background:#2a2a3e;border-color:#3a3a5c}.room-cell.unexplored{opacity:.5;filter:grayscale(.5)}.room-cell.explored{opacity:1}.room-cell.cleared{opacity:.7}.room-cell.current{border-color:#fff!important;box-shadow:0 0 15px #ffffff80;transform:scale(1.05)}.room-cell.can-move{cursor:pointer;animation:canMovePulse 1.5s ease-in-out infinite}.room-cell.can-move:hover{transform:scale(1.1);box-shadow:0 0 15px #e9456080}@keyframes canMovePulse{0%,to{border-color:#e9456080}50%{border-color:#e94560}}.room-cell:disabled{cursor:not-allowed}.room-cell.blocked{opacity:.4;border-color:#666!important;position:relative}.room-cell.blocked:after{content:"🚫";position:absolute;top:-4px;right:-4px;font-size:.75rem}.room-icon{font-size:1.5rem}.room-number{font-size:.65rem;color:#ffffffb3;margin-top:2px}.current-indicator{position:absolute;top:-8px;right:-8px;font-size:1rem}.cleared-indicator{position:absolute;bottom:2px;right:4px;font-size:.75rem;color:#4caf50;font-weight:700}.room-connections{position:absolute;inset:1rem;pointer-events:none;z-index:1}.connection-line{stroke:#3a3a5c;stroke-width:3;stroke-linecap:round}.connection-line.explored{stroke:#6a6a8c}.room-legend{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #3a3a5c}.legend-item{display:flex;align-items:center;gap:.25rem;font-size:.8rem;color:#8b8b8b}.legend-item span{font-size:1rem}@media(max-width:768px){.room-cell{min-width:50px;min-height:50px}.room-icon{font-size:1.25rem}.room-legend{font-size:.7rem}}@media(max-width:480px){.room-grid-container{padding:.5rem}.room-grid{gap:4px}.room-cell{min-width:40px;min-height:40px;border-radius:6px}.room-icon{font-size:1rem}.room-number{font-size:.55rem}.current-indicator{font-size:.8rem;top:-6px;right:-6px}.cleared-indicator{font-size:.6rem}.room-legend{gap:.5rem;margin-top:1rem;padding-top:.75rem}.legend-item{font-size:.7rem;gap:.15rem}.legend-item span{font-size:.85rem}}.room-event-panel{background:#16213e;border-radius:12px;padding:1.5rem;min-height:200px}.room-event-panel.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#8b8b8b}.room-event-panel.empty h3{margin:0 0 .5rem}.room-content{text-align:center}.room-icon-large{font-size:3rem;margin-bottom:1rem}.room-content h3{margin:0 0 1rem;font-size:1.25rem}.room-content p{margin:.5rem 0;color:#ccc}.cleared-text{color:#4caf50!important;font-style:italic}.warning-text{color:#f44336!important;font-weight:600}.action-btn{margin-top:1rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.action-btn:disabled{opacity:.5;cursor:not-allowed}.treasure-btn{background:linear-gradient(135deg,#f57f17,#ff8f00);color:#fff}.treasure-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #f57f1766}.rest-btn{background:linear-gradient(135deg,#1976d2,#2196f3);color:#fff}.rest-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #2196f366}.treasure-info{font-size:1.5rem;margin:1rem 0;color:#ffca28}.trap-info{font-size:1.25rem;margin:1rem 0;color:#f44336}.gold-display{font-size:1.1rem;color:#ffca28!important;font-weight:600;margin-bottom:1rem!important}.shop-items{display:flex;flex-direction:column;gap:.75rem;max-height:300px;overflow-y:auto;text-align:left}.shop-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#1a1a2e;border-radius:8px}.item-info{display:flex;flex-direction:column;gap:.25rem}.item-name{font-weight:600}.item-name.rarity-common{color:#9e9e9e}.item-name.rarity-uncommon{color:#4caf50}.item-name.rarity-rare{color:#2196f3}.item-name.rarity-epic{color:#9c27b0}.item-name.rarity-legendary{color:#ff9800}.item-type{font-size:.75rem;color:#8b8b8b;text-transform:capitalize}.item-price{display:flex;align-items:center;gap:.75rem}.buy-btn{padding:.4rem .75rem;font-size:.85rem;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:opacity .2s}.buy-btn:hover:not(:disabled){opacity:.9}.buy-btn:disabled{background:#666;cursor:not-allowed}.inventory-panel{padding:.5rem}.inventory-panel h2{margin:0 0 1rem;text-align:center}.gold-display{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:1.25rem;font-weight:600;color:#ffca28;margin-bottom:1rem}.inventory-tabs{display:flex;gap:.5rem;margin-bottom:1rem}.tab-btn{flex:1;padding:.75rem;background:#1a1a2e;color:#8b8b8b;border:2px solid transparent;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s}.tab-btn:hover{background:#252545}.tab-btn.active{color:#fff;border-color:#e94560;background:#252545}.inventory-content{margin-bottom:1rem}.empty-text{text-align:center;color:#8b8b8b;font-style:italic;padding:2rem}.inventory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem;max-height:300px;overflow-y:auto}.inventory-item{background:#1a1a2e;border-radius:8px;padding:.75rem;cursor:pointer;border:2px solid transparent;transition:all .2s}.inventory-item:hover{transform:translateY(-2px)}.inventory-item.selected{border-color:#e94560}.inventory-item.rarity-common{border-left:3px solid #9e9e9e}.inventory-item.rarity-uncommon{border-left:3px solid #4caf50}.inventory-item.rarity-rare{border-left:3px solid #2196f3}.inventory-item.rarity-epic{border-left:3px solid #9c27b0}.inventory-item.rarity-legendary{border-left:3px solid #ff9800}.item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.item-name{font-weight:600;font-size:.9rem}.item-quantity{background:#e94560;padding:.1rem .4rem;border-radius:4px;font-size:.75rem}.item-meta{display:flex;justify-content:space-between;font-size:.75rem}.item-type{color:#8b8b8b;text-transform:capitalize}.item-rarity{text-transform:capitalize}.rarity-common{color:#9e9e9e}.rarity-uncommon{color:#4caf50}.rarity-rare{color:#2196f3}.rarity-epic{color:#9c27b0}.rarity-legendary{color:#ff9800}.equipment-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.equipment-slot{background:#1a1a2e;border-radius:8px;padding:.75rem}.slot-label{font-size:.75rem;color:#8b8b8b;text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem}.equipped-item{display:flex;justify-content:space-between;align-items:center}.equipped-item .item-name{font-size:.85rem}.unequip-btn{padding:.25rem .5rem;background:#f44336;color:#fff;border:none;border-radius:4px;font-size:.7rem;cursor:pointer}.empty-slot{color:#555;font-style:italic;font-size:.85rem}.equipment-stats{grid-column:1 / -1;background:#252545;border-radius:8px;padding:1rem;margin-top:.5rem}.equipment-stats h4{margin:0 0 .75rem;font-size:.9rem;color:#8b8b8b}.stat-row{display:flex;justify-content:space-between;padding:.25rem 0;font-size:.9rem}.stat-value{color:#4caf50;font-weight:600}.item-details{background:#252545;border-radius:8px;padding:1rem;border:1px solid #3a3a5c}.item-details h4{margin:0 0 .5rem}.item-description{color:#8b8b8b;font-size:.85rem;margin:0 0 .75rem}.item-stats{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.75rem;font-size:.9rem}.special-effect{color:#ce93d8}.item-requirements{display:flex;gap:1rem;font-size:.8rem;color:#8b8b8b;margin-bottom:.75rem}.item-actions{display:flex;gap:.5rem}.equip-btn{flex:1;padding:.5rem;background:#4caf50;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600}.sell-btn{padding:.5rem 1rem;background:#ff9800;color:#fff;border:none;border-radius:6px;cursor:pointer}.equip-btn:hover,.sell-btn:hover{opacity:.9}.monster-sprite-container{display:flex;align-items:center;justify-content:center;width:200px;height:200px}.monster-sprite-container.boss{width:280px;height:280px}.monster-sprite{width:100%;height:100%;transition:transform .3s ease}.monster-sprite.boss{filter:drop-shadow(0 0 20px rgba(156,39,176,.6))}.monster-sprite.hit{animation:shake .4s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}15%{transform:translate(-12px) rotate(-2deg)}30%{transform:translate(10px) rotate(2deg)}45%{transform:translate(-8px) rotate(-1deg)}60%{transform:translate(6px) rotate(1deg)}75%{transform:translate(-4px)}90%{transform:translate(2px)}}.wobble{animation:wobble 2s ease-in-out infinite;transform-origin:center bottom}@keyframes wobble{0%,to{transform:scaleY(1) scaleX(1)}25%{transform:scaleY(.92) scaleX(1.08)}50%{transform:scaleY(1.05) scaleX(.95)}75%{transform:scaleY(.95) scaleX(1.05)}}.glow{animation:glow 2s ease-in-out infinite}@keyframes glow{0%,to{opacity:1;filter:drop-shadow(0 0 3px currentColor)}50%{opacity:.7;filter:drop-shadow(0 0 8px currentColor)}}.rat{animation:ratMove 3s ease-in-out infinite}.rat:nth-child(2){animation-delay:-1s}.rat:nth-child(3){animation-delay:-2s}@keyframes ratMove{0%,to{transform:translate(0) translateY(0)}25%{transform:translate(2px) translateY(-1px)}50%{transform:translate(-1px) translateY(1px)}75%{transform:translate(1px) translateY(-2px)}}.monster-sprite-container{animation:monsterAppear .5s ease-out}@keyframes monsterAppear{0%{opacity:0;transform:scale(.8) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.monster-sprite-container.boss{animation:bossAppear .8s ease-out}@keyframes bossAppear{0%{opacity:0;transform:scale(.5) translateY(50px);filter:brightness(2)}50%{opacity:1;transform:scale(1.1) translateY(-10px);filter:brightness(1.3)}to{opacity:1;transform:scale(1) translateY(0);filter:brightness(1)}}@media(max-width:768px){.monster-sprite-container{width:150px;height:150px}.monster-sprite-container.boss{width:200px;height:200px}}@media(max-width:480px){.monster-sprite-container{width:120px;height:120px}.monster-sprite-container.boss{width:160px;height:160px}}.party-battle-status{width:100%;padding:.5rem}.party-cards{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.party-card{background:#16213ee6;border:2px solid #0f4c75;border-radius:12px;padding:.75rem 1rem;min-width:120px;text-align:center;position:relative;transition:transform .2s,border-color .2s}.party-card.current-user{border-color:#e94560}.party-card.dead{opacity:.5;filter:grayscale(.5)}.party-card.damage-flash{animation:damageFlash .5s ease-out}@keyframes damageFlash{0%{background:#f4433666;transform:scale(1.05)}to{background:#16213ee6;transform:scale(1)}}.party-card.heal-flash{animation:healFlash .5s ease-out}@keyframes healFlash{0%{background:#4caf5066;transform:scale(1.05)}to{background:#16213ee6;transform:scale(1)}}.card-icon{font-size:2rem;margin-bottom:.25rem}.card-name{font-weight:600;font-size:.9rem;color:#fff;margin-bottom:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.you-marker{color:#e94560;margin-left:.25rem}.card-class{font-size:.7rem;color:#8b8b8b;text-transform:capitalize;margin-bottom:.5rem}.card-health-bar{height:10px;background:#1a1a2e;border-radius:5px;overflow:hidden;margin-bottom:.25rem}.card-health-fill{height:100%;background:linear-gradient(90deg,#4caf50,#81c784);border-radius:5px;transition:width .3s ease}.card-health-fill.low{background:linear-gradient(90deg,#f44336,#ff7043)}.card-health-fill.dead{width:0!important;background:#424242}.card-health-text{font-size:.75rem;color:#ccc}.card-health-text.low{color:#ff7043}.dead-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0009;border-radius:10px;font-size:1rem;font-weight:700;color:#f44336;letter-spacing:2px}@media(max-width:768px){.party-cards{gap:.5rem}.party-card{min-width:100px;padding:.5rem .75rem}.card-icon{font-size:1.5rem}.card-name{font-size:.8rem}.card-class{font-size:.65rem}.card-health-bar{height:8px}.card-health-text{font-size:.65rem}}@media(max-width:480px){.party-cards{gap:.4rem}.party-card{min-width:80px;padding:.4rem .5rem}.card-icon{font-size:1.25rem}.card-name{font-size:.7rem}.card-class{display:none}.card-health-bar{height:6px}.card-health-text{font-size:.6rem}}.combat-actions{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1rem;width:100%}.combat-actions.cleared{justify-content:center}.victory-message{font-size:2rem;font-weight:700;color:#4caf50;text-shadow:0 0 20px rgba(76,175,80,.5);animation:victoryPulse 1s ease-in-out infinite}.attack-button{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 3rem;font-size:1.5rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#e94560,#c72c4f);border:none;border-radius:12px;cursor:pointer;transition:all .2s;box-shadow:0 4px 15px #e9456066;min-width:200px}.attack-button:hover:not(:disabled){transform:translateY(-2px) scale(1.02);box-shadow:0 6px 20px #e9456080}.attack-button:active:not(:disabled){transform:translateY(0) scale(.98)}.attack-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.attack-icon{font-size:1.75rem}.attack-text{letter-spacing:2px}.loading-text{font-size:1.25rem;letter-spacing:1px}.skill-buttons{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem}.skill-button{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem 1.25rem;background:linear-gradient(135deg,#7c4dff,#651fff);border:none;border-radius:8px;color:#fff;cursor:pointer;transition:all .2s;min-width:100px}.skill-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #7c4dff66}.skill-button:disabled{opacity:.5;cursor:not-allowed}.skill-name{font-size:.9rem;font-weight:600}.skill-cost{font-size:.75rem;opacity:.8}.no-skills-hint{font-size:.85rem;color:#8b8b8b;font-style:italic}@media(max-width:768px){.attack-button{padding:.875rem 2rem;font-size:1.25rem;min-width:160px}.attack-icon{font-size:1.5rem}.skill-button{padding:.6rem 1rem;min-width:85px}.skill-name{font-size:.8rem}}@media(max-width:480px){.combat-actions{gap:.75rem;padding:.75rem}.attack-button{padding:.75rem 1.5rem;font-size:1rem;min-width:140px}.attack-icon{font-size:1.25rem}.skill-buttons{gap:.5rem}.skill-button{padding:.5rem .75rem;min-width:70px}.skill-name{font-size:.7rem}.skill-cost{font-size:.65rem}}.combat-log{background:#0a0a1acc;border:1px solid #0f4c75;border-radius:8px;padding:.75rem;max-height:150px;overflow-y:auto;width:100%;max-width:500px}.combat-log::-webkit-scrollbar{width:6px}.combat-log::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.combat-log::-webkit-scrollbar-thumb{background:#0f4c75;border-radius:3px}.log-empty{text-align:center;color:#8b8b8b;font-style:italic;padding:1rem}.log-entries{display:flex;flex-direction:column;gap:.5rem}.log-entry{display:flex;align-items:flex-start;gap:.5rem;padding:.35rem .5rem;border-radius:4px;font-size:.85rem}.log-entry.animate-in{animation:logSlideIn .3s ease-out}@keyframes logSlideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.entry-icon{flex-shrink:0;font-size:1rem}.entry-text{color:#ccc}.entry-text strong{color:#fff}.log-entry.critical{background:#ffd70026;border-left:3px solid #ffd700}.log-entry.critical .entry-text{color:gold;font-weight:700}.log-entry.dodged{background:#2196f326;border-left:3px solid #2196f3}.log-entry.dodged .entry-text{color:#64b5f6}.log-entry.death-save{background:#9c27b026;border-left:3px solid #9c27b0}.log-entry.death-save .entry-text{color:#ce93d8}.log-entry.damage-dealt{background:#4caf501a}.log-entry.damage-dealt .entry-text strong{color:#4caf50}.log-entry.damage-taken{background:#f443361a}.log-entry.damage-taken .entry-text strong{color:#f44336}.log-entry.effects{flex-wrap:wrap}.effects-list{display:flex;flex-wrap:wrap;gap:.35rem}.effect-tag{background:#7c4dff33;color:#b388ff;padding:.15rem .5rem;border-radius:4px;font-size:.75rem}.log-entry.hp-remaining{opacity:.7;font-size:.8rem}.log-entry.victory{background:linear-gradient(90deg,#4caf5033,#4caf500d);border-left:3px solid #4caf50}.log-entry.victory .entry-text{color:#4caf50;font-weight:700;font-size:1rem}.log-entry.loot{background:#ffc1071a}.log-entry.loot .entry-text strong{color:#ffc107}.log-entry.items{background:#9c27b01a}.log-entry.items .entry-text{color:#ce93d8}@media(max-width:768px){.combat-log{max-height:120px;padding:.5rem}.log-entry{font-size:.8rem;padding:.25rem .4rem}.entry-icon{font-size:.9rem}}@media(max-width:480px){.combat-log{max-height:100px}.log-entry{font-size:.75rem}.effect-tag{font-size:.65rem;padding:.1rem .35rem}}.fullscreen-combat{position:fixed;inset:0;background:linear-gradient(180deg,#0a0a1a,#1a1a2e,#16213e);z-index:1000;display:grid;grid-template-rows:auto 1fr auto auto auto;overflow:hidden;animation:combatEnter .4s ease-out}.fullscreen-combat.boss-combat{background:linear-gradient(180deg,#1a0a1a,#2a1a3e,#1a1630)}.fullscreen-combat.boss-combat:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center top,rgba(156,39,176,.15) 0%,transparent 60%);pointer-events:none}@keyframes combatEnter{0%{opacity:0;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.fullscreen-combat.exiting{animation:combatExit .3s ease-in forwards}@keyframes combatExit{to{opacity:0;transform:scale(.95)}}.combat-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#0000004d;border-bottom:1px solid rgba(255,255,255,.1)}.combat-title{font-size:1.5rem;font-weight:700;color:#e94560;text-shadow:0 0 10px rgba(233,69,96,.5)}.fullscreen-combat.boss-combat .combat-title{color:#9c27b0;text-shadow:0 0 15px rgba(156,39,176,.6);font-size:1.75rem}.floor-indicator{color:#8b8b8b;font-size:1rem}.flee-button{padding:.5rem 1.25rem;background:transparent;border:1px solid #8b8b8b;border-radius:6px;color:#8b8b8b;cursor:pointer;transition:all .2s}.flee-button:hover:not(:disabled){border-color:#fff;color:#fff}.flee-button:disabled{opacity:.5;cursor:not-allowed}.monster-section{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;gap:1rem}.monster-info{text-align:center;width:100%;max-width:400px}.monster-name{font-size:1.5rem;font-weight:700;color:#fff;margin:0 0 .75rem}.monster-name.boss-name{font-size:1.75rem;color:#9c27b0;text-shadow:0 0 10px rgba(156,39,176,.5)}.monster-hp-bar{position:relative;height:24px;background:#00000080;border-radius:12px;overflow:hidden;border:2px solid #333}.monster-hp-fill{height:100%;background:linear-gradient(90deg,#f44336,#ff5252,#ff8a80);border-radius:10px;transition:width .3s ease}.monster-hp-fill.low{background:linear-gradient(90deg,#b71c1c,#c62828,#d32f2f);animation:lowHpPulse 1s ease-in-out infinite}@keyframes lowHpPulse{0%,to{opacity:1}50%{opacity:.7}}.monster-hp-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.monster-stats{margin-top:.5rem;display:flex;justify-content:center;gap:1rem}.stat{display:flex;align-items:center;gap:.35rem;color:#ccc;font-size:.9rem}.stat-icon{font-size:1rem}.party-section{padding:.5rem 1rem;display:flex;justify-content:center}.log-section{padding:0 1rem;display:flex;justify-content:center}.actions-section{padding:1rem;display:flex;justify-content:center;background:#0003;border-top:1px solid rgba(255,255,255,.1)}.victory-overlay{display:flex;align-items:center;justify-content:center;width:100%;animation:victoryFadeIn .5s ease-out}@keyframes victoryFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.victory-content{text-align:center;padding:1.5rem 2rem;background:#16213ef2;border:2px solid #4caf50;border-radius:16px;box-shadow:0 0 30px #4caf504d}.victory-title{font-size:2rem;color:#4caf50;margin:0 0 1rem;text-shadow:0 0 20px rgba(76,175,80,.5);animation:victoryPulse 1s ease-in-out infinite}@keyframes victoryPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.victory-loot{margin-bottom:.75rem}.loot-gold{font-size:1.25rem;color:#ffc107;font-weight:700}.loot-bonus{font-size:.85rem;color:#ffca28;margin-left:.5rem}.victory-items{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem}.loot-item{color:#ce93d8;font-size:.95rem}.floor-complete{font-size:1rem;color:#64b5f6;margin-bottom:1rem;font-weight:700}.continue-button{padding:.75rem 2rem;font-size:1.1rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#4caf50,#388e3c);border:none;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s}.continue-button:hover{transform:translateY(-2px);box-shadow:0 4px 15px #4caf5066}@media(max-width:768px){.combat-header{padding:.75rem 1rem}.combat-title{font-size:1.25rem}.fullscreen-combat.boss-combat .combat-title{font-size:1.35rem}.floor-indicator{font-size:.85rem}.flee-button{padding:.4rem .75rem;font-size:.85rem}.monster-section{padding:.75rem}.monster-name{font-size:1.25rem}.monster-name.boss-name{font-size:1.4rem}.monster-hp-bar{height:20px}.monster-hp-text{font-size:.75rem}.party-section{padding:.35rem .75rem}.log-section{padding:0 .75rem}.actions-section{padding:.75rem}}@media(max-width:480px){.fullscreen-combat{grid-template-rows:auto auto 1fr auto auto auto}.combat-header{flex-wrap:wrap;gap:.5rem;padding:.5rem .75rem}.combat-title{font-size:1rem;width:100%;text-align:center}.floor-indicator{font-size:.75rem}.flee-button{padding:.3rem .6rem;font-size:.75rem}.monster-section{padding:.5rem;gap:.5rem}.monster-info{max-width:300px}.monster-name{font-size:1.1rem;margin-bottom:.5rem}.monster-hp-bar{height:16px}.monster-hp-text{font-size:.7rem}.stat{font-size:.8rem}.victory-content{padding:1rem 1.25rem}.victory-title{font-size:1.5rem}.loot-gold{font-size:1rem}.continue-button{padding:.6rem 1.5rem;font-size:1rem}}.dashboard{min-height:100vh;background:linear-gradient(180deg,var(--color-background) 0%,var(--color-background-secondary) 50%,var(--color-background) 100%);font-family:system-ui,-apple-system,sans-serif;color:#e8e6e3;position:relative}.dashboard:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 20% 20%,color-mix(in srgb,var(--color-highlight) 8%,transparent) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,color-mix(in srgb,var(--color-highlight) 6%,transparent) 0%,transparent 50%);pointer-events:none;z-index:0}.notification{position:fixed;top:20px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,var(--color-highlight) 0%,var(--color-button) 100%);color:#fff;padding:12px 24px;border-radius:12px;z-index:1000;font-weight:500;box-shadow:0 4px 20px color-mix(in srgb,var(--color-highlight) 40%,transparent)}.party-notifications{position:fixed;top:80px;right:20px;z-index:999;display:flex;flex-direction:column;gap:8px}.party-notification{background:#22c55ee6;color:#fff;padding:10px 16px;border-radius:10px;font-size:13px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(100px);opacity:0}to{transform:translate(0);opacity:1}}.top-bar{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:color-mix(in srgb,var(--color-background) 95%,white);border-bottom:1px solid color-mix(in srgb,var(--color-highlight) 15%,transparent);position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.top-bar-left{display:flex;align-items:center;gap:12px}.party-name{font-size:14px;font-weight:600;color:var(--color-highlight)}.banner-actions{display:flex;gap:6px;align-items:center}.banner-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;transition:all .2s}.banner-btn.active{background:var(--color-highlight);border-color:var(--color-highlight);padding:6px 10px;color:#9ca3af;cursor:pointer;font-size:14px;transition:all .2s}.banner-btn:hover{background:#ffffff1a;color:#e8e6e3}.status-row{display:grid;grid-template-columns:auto 1fr;gap:16px;padding:16px 24px;position:relative;z-index:1}@media(max-width:900px){.status-row{grid-template-columns:1fr}}.party-members-card{background:#0003;border-radius:16px;padding:12px;border:1px solid rgba(255,255,255,.05)}.party-members-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:12px;color:#9ca3af;padding:0 4px}.party-energy{color:#fbbf24;font-weight:600}.party-members-grid{display:flex;gap:8px;flex-wrap:wrap}.party-member-card{flex:1 1 100px;min-width:100px;max-width:140px;background:#ffffff08;border-radius:10px;padding:10px;border:1px solid rgba(255,255,255,.05);transition:all .2s}.party-member-card.current-user{background:linear-gradient(135deg,color-mix(in srgb,var(--color-highlight) 15%,transparent),color-mix(in srgb,var(--color-button) 10%,transparent));border-color:color-mix(in srgb,var(--color-highlight) 30%,transparent)}.party-member-card.dead{opacity:.5}.member-header{display:flex;align-items:center;gap:6px;margin-bottom:6px}.member-avatar{font-size:16px;position:relative;display:inline-block}.status-dot{position:absolute;bottom:-2px;right:-2px;width:8px;height:8px;border-radius:50%;border:1px solid rgba(0,0,0,.3)}.status-dot.green{background:#22c55e;box-shadow:0 0 4px #22c55e}.status-dot.blue{background:#3b82f6;box-shadow:0 0 4px #3b82f6}.status-dot.red{background:#ef4444;box-shadow:0 0 4px #ef4444}.member-name{font-size:11px;font-weight:600;color:#e8e6e3}.party-member-card.current-user .member-name{color:color-mix(in srgb,var(--color-highlight) 70%,white)}.member-streak{font-size:9px;color:#6b7280}.member-hp-bar{height:5px;background:#0006;border-radius:3px;overflow:hidden}.member-hp-fill{height:100%;border-radius:3px;transition:width .3s ease}.member-hp-fill.high{background:linear-gradient(90deg,#4ade80,#22c55e)}.member-hp-fill.medium{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.member-hp-fill.low{background:linear-gradient(90deg,#f87171,#ef4444)}.member-hp-text{font-size:9px;color:#6b7280;margin-top:3px;text-align:right}.dungeon-map-section{padding:16px 24px;background:linear-gradient(180deg,color-mix(in srgb,var(--color-highlight) 5%,transparent) 0%,transparent 100%);position:relative;z-index:1}.dungeon-map-container{background:#0000004d;border-radius:16px;padding:16px;border:1px solid color-mix(in srgb,var(--color-highlight) 10%,transparent);position:relative;height:100px;overflow:hidden}.map-label{position:absolute;top:8px;left:12px;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:#6b7280}.map-svg{position:absolute;top:0;left:0;width:100%;height:100%}.map-explore-btn{position:absolute;bottom:8px;right:12px;font-size:11px;color:var(--color-highlight);display:flex;align-items:center;gap:4px;cursor:pointer;background:none;border:none;padding:4px 8px;border-radius:8px;transition:all .2s}.map-explore-btn:hover{background:color-mix(in srgb,var(--color-highlight) 20%,transparent)}.tasks-section{padding:20px 24px;position:relative;z-index:1}.tasks-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media(max-width:1200px){.tasks-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.tasks-grid{grid-template-columns:1fr}}.task-column{background:#0003;border-radius:16px;padding:16px;border:1px solid rgba(255,255,255,.05)}.column-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.05)}.filter-buttons{display:flex;gap:6px;margin-bottom:10px}.filter-btn{padding:4px 10px;font-size:11px;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;color:#fff9;border-radius:12px;cursor:pointer;transition:all .2s}.filter-btn:hover{background:#ffffff1a;color:#fffc}.filter-btn.active{background:var(--color-highlight);border-color:var(--color-highlight);color:#fff}.column-title{display:flex;align-items:center;gap:8px}.column-title h3{font-size:14px;font-weight:600;color:#e8e6e3;margin:0}.column-count{background:color-mix(in srgb,var(--color-highlight) 30%,transparent);color:color-mix(in srgb,var(--color-highlight) 70%,white);font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px}.add-task-btn{width:28px;height:28px;border-radius:8px;border:2px solid color-mix(in srgb,var(--color-highlight) 30%,transparent);background:color-mix(in srgb,var(--color-highlight) 10%,transparent);color:var(--color-highlight);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.add-task-btn:hover{background:color-mix(in srgb,var(--color-highlight) 20%,transparent);border-color:color-mix(in srgb,var(--color-highlight) 50%,transparent)}.task-list{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}.task-list::-webkit-scrollbar{width:4px}.task-list::-webkit-scrollbar-track{background:transparent}.task-list::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--color-highlight) 30%,transparent);border-radius:2px}.task-item{background:#ffffff08;border-radius:12px;padding:12px;border:1px solid rgba(255,255,255,.05);cursor:pointer;display:flex;align-items:center;gap:12px;transition:all .2s}.task-item:hover{background:#ffffff0d;border-color:#ffffff1a}.task-item.completed{background:linear-gradient(135deg,#22c55e1a,#22c55e0d);border-color:#22c55e33}.task-checkbox{width:24px;height:24px;border-radius:6px;border:2px solid rgba(255,255,255,.2);background:transparent;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:all .2s;color:#fff;font-size:12px}.task-checkbox:hover{border-color:#22c55e80}.task-checkbox.checked{border-color:#22c55e;background:linear-gradient(135deg,#22c55e,#16a34a)}.task-content{flex:1;min-width:0}.task-name{font-size:14px;font-weight:500;color:#e8e6e3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-item.completed .task-name{color:#86efac;text-decoration:line-through;opacity:.7}.task-meta{font-size:11px;color:#6b7280;margin-top:2px;display:flex;align-items:center;gap:8px}.task-difficulty{font-size:9px;text-transform:uppercase;letter-spacing:1px;padding:2px 6px;border-radius:4px;font-weight:600}.task-difficulty.trivial{color:#9ca3af;background:#9ca3af1a}.task-difficulty.easy{color:#4ade80;background:#4ade801a}.task-difficulty.medium{color:#fbbf24;background:#fbbf241a}.task-difficulty.hard{color:#f87171;background:#f871711a}.habit-item{background:#ffffff08;border-radius:12px;padding:12px;border:1px solid rgba(255,255,255,.05);display:flex;align-items:center;gap:10px}.habit-btn{width:32px;height:32px;border-radius:8px;border:2px solid;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.habit-btn.negative{border-color:#ef44444d;background:#ef44441a;color:#f87171}.habit-btn.negative:hover{background:#ef444433;border-color:#ef444480}.habit-btn.positive{border-color:#22c55e4d;background:#22c55e1a;color:#4ade80}.habit-btn.positive:hover{background:#22c55e33;border-color:#22c55e80}.habit-btn:disabled{opacity:.3;cursor:not-allowed}.habit-content{flex:1;text-align:center;min-width:0}.habit-name{font-size:14px;font-weight:500;color:#e8e6e3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.habit-counts{font-size:11px;color:#6b7280;margin-top:4px;display:flex;justify-content:center;gap:12px}.habit-counts .positive{color:#4ade80}.habit-counts .negative{color:#f87171}.empty-state{text-align:center;padding:24px 16px;color:#6b7280;font-size:13px}.warning-banner{margin:16px 24px;padding:14px 16px;background:linear-gradient(135deg,#fb923c1a,#fb923c0d);border-radius:12px;border:1px solid rgba(251,146,60,.2);display:flex;align-items:center;gap:12px;position:relative;z-index:1}.warning-icon{font-size:20px}.warning-title{font-size:13px;font-weight:600;color:#fbbf24}.warning-text{font-size:12px;color:#9ca3af}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(180deg,transparent 0%,color-mix(in srgb,var(--color-background) 98%,black) 20%);padding:40px 20px 20px;z-index:100}.bottom-nav-inner{max-width:600px;margin:0 auto;display:flex;justify-content:space-around;align-items:center;background:color-mix(in srgb,var(--color-background) 95%,white);border-radius:20px;padding:10px 8px;border:1px solid color-mix(in srgb,var(--color-highlight) 15%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;opacity:.6;cursor:pointer;padding:4px 12px;border-radius:12px;background:transparent;border:none;transition:all .2s}.nav-item:hover{opacity:.8}.nav-item.active{opacity:1;background:linear-gradient(135deg,color-mix(in srgb,var(--color-highlight) 20%,transparent),color-mix(in srgb,var(--color-button) 10%,transparent))}.nav-item.highlight{background:linear-gradient(135deg,#fbbf2433,#fb923c1a);opacity:1}.nav-icon{font-size:20px}.nav-label{font-size:10px;color:#6b7280;font-weight:400}.nav-item.active .nav-label{color:var(--color-highlight);font-weight:600}.nav-item.highlight .nav-label{color:#fbbf24}.bottom-spacer{height:100px}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:linear-gradient(135deg,var(--color-background-secondary) 0%,var(--color-background) 100%);border-radius:20px;padding:24px;width:100%;max-width:400px;border:1px solid color-mix(in srgb,var(--color-highlight) 20%,transparent);box-shadow:0 20px 60px #00000080}.modal h3{font-size:18px;font-weight:600;color:#e8e6e3;margin:0 0 20px}.modal-input{width:100%;padding:12px 16px;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#e8e6e3;font-size:14px;margin-bottom:16px;box-sizing:border-box}.modal-input:focus{outline:none;border-color:color-mix(in srgb,var(--color-highlight) 50%,transparent)}.modal-input::placeholder{color:#6b7280}.difficulty-picker{display:flex;gap:8px;margin-bottom:16px}.diff-option{flex:1;padding:10px 8px;border:2px solid transparent;border-radius:10px;cursor:pointer;font-size:11px;font-weight:500;text-align:center;transition:all .2s;background:#ffffff0d;color:#9ca3af}.diff-option:hover{background:#ffffff1a}.diff-option.selected{border-color:currentColor}.diff-option.trivial.selected{color:#9ca3af;background:#9ca3af33}.diff-option.easy.selected{color:#4ade80;background:#4ade8033}.diff-option.medium.selected{color:#fbbf24;background:#fbbf2433}.diff-option.hard.selected{color:#f87171;background:#f8717133}.schedule-picker{margin-bottom:16px}.schedule-label{font-size:12px;color:#9ca3af;margin-bottom:8px}.schedule-options{display:flex;flex-wrap:wrap;gap:6px}.schedule-option{padding:8px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#9ca3af;font-size:12px;cursor:pointer;transition:all .2s}.schedule-option:hover{background:#ffffff1a}.schedule-option.selected{background:color-mix(in srgb,var(--color-highlight) 20%,transparent);border-color:color-mix(in srgb,var(--color-highlight) 40%,transparent);color:color-mix(in srgb,var(--color-highlight) 70%,white)}.direction-picker{margin-bottom:16px}.direction-picker label{font-size:12px;color:#9ca3af;display:block;margin-bottom:8px}.direction-options{display:flex;gap:8px}.direction-btn{flex:1;padding:10px;border:2px solid rgba(255,255,255,.1);border-radius:10px;background:#ffffff0d;color:#9ca3af;font-size:13px;cursor:pointer;transition:all .2s}.direction-btn.selected{border-color:color-mix(in srgb,var(--color-highlight) 40%,transparent);background:color-mix(in srgb,var(--color-highlight) 20%,transparent);color:color-mix(in srgb,var(--color-highlight) 70%,white)}.modal-actions{display:flex;gap:12px;margin-top:20px}.cancel-btn{flex:1;padding:12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#9ca3af;font-size:14px;cursor:pointer;transition:all .2s}.cancel-btn:hover{background:#ffffff1a}.primary-btn{flex:1;padding:12px;background:linear-gradient(135deg,var(--color-button) 0%,var(--color-button-hover) 100%);border:none;border-radius:12px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.primary-btn:hover{opacity:.9;transform:translateY(-1px)}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(180deg,var(--color-background) 0%,var(--color-background-secondary) 100%);color:var(--color-highlight);font-size:16px}.subtask-list{background:#0003;border-radius:8px;margin-top:8px;padding:8px}.subtask-item{display:flex;align-items:center;gap:8px;padding:6px 8px;font-size:12px;color:#9ca3af}.subtask-item.completed{text-decoration:line-through;opacity:.6}.subtask-checkbox{width:16px;height:16px;border-radius:4px;border:1px solid rgba(255,255,255,.2);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff}.subtask-checkbox.checked{background:#22c55e;border-color:#22c55e}.subtask-add{display:flex;gap:6px;margin-top:8px}.subtask-add input{flex:1;padding:6px 10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#e8e6e3;font-size:12px}.subtask-add button{padding:6px 10px;background:color-mix(in srgb,var(--color-highlight) 20%,transparent);border:none;border-radius:6px;color:var(--color-highlight);cursor:pointer}.task-actions{display:flex;gap:4px}.expand-btn,.delete-btn{width:24px;height:24px;border-radius:6px;border:none;background:#ffffff0d;color:#6b7280;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.expand-btn:hover{background:color-mix(in srgb,var(--color-highlight) 20%,transparent);color:var(--color-highlight)}.delete-btn:hover{background:#ef444433;color:#f87171}.no-party-section{padding:40px 24px;text-align:center;position:relative;z-index:1}.no-party-card{background:#0000004d;border-radius:20px;padding:32px;border:1px solid color-mix(in srgb,var(--color-highlight) 10%,transparent);max-width:400px;margin:0 auto}.no-party-card h2{font-size:20px;color:#e8e6e3;margin:0 0 8px}.no-party-card p{color:#9ca3af;font-size:14px;margin:0 0 24px}.no-party-buttons{display:flex;gap:12px;justify-content:center}.secondary-btn{padding:12px 24px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#9ca3af;font-size:14px;cursor:pointer;transition:all .2s}.secondary-btn:hover{background:#ffffff1a;color:#e8e6e3}.chat-section{padding:0 24px 24px;position:relative;z-index:1}.inventory-modal{max-width:600px;max-height:80vh;overflow-y:auto}.modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:8px;border:none;background:#ffffff1a;color:#9ca3af;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#fff3;color:#e8e6e3}.skills-panel-container{padding:0 24px 24px;position:relative;z-index:1}.become-todo-toggle{margin-top:16px;padding:12px;background:#ffffff08;border-radius:10px}.toggle-label{display:flex;align-items:center;gap:10px;font-size:13px;color:#e8e6e3;cursor:pointer}.toggle-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-highlight)}.toggle-hint{font-size:11px;color:#6b7280;margin-top:6px;margin-left:28px}.schedule-sub-option{margin-top:12px}.schedule-sub-option label{display:block;font-size:12px;color:#9ca3af;margin-bottom:6px}.modal-select{width:100%;padding:10px 12px;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#e8e6e3;font-size:14px}.day-picker{display:flex;gap:6px;margin-top:12px}.day-btn{flex:1;padding:8px 4px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#9ca3af;font-size:11px;cursor:pointer;transition:all .2s}.day-btn.selected{background:color-mix(in srgb,var(--color-highlight) 20%,transparent);border-color:color-mix(in srgb,var(--color-highlight) 40%,transparent);color:color-mix(in srgb,var(--color-highlight) 70%,white)}.due-date-picker{margin-bottom:16px}.due-date-picker label{display:block;font-size:12px;color:#9ca3af;margin-bottom:6px}.dungeon-minimap{padding:12px;background:linear-gradient(135deg,color-mix(in srgb,var(--color-highlight) 10%,transparent),#0000004d);border-radius:16px;border:1px solid color-mix(in srgb,var(--color-highlight) 20%,transparent);cursor:pointer;transition:all .2s;align-self:start}.dungeon-minimap:hover{background:linear-gradient(135deg,color-mix(in srgb,var(--color-highlight) 15%,transparent),#0000004d);border-color:color-mix(in srgb,var(--color-highlight) 30%,transparent)}.minimap-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.minimap-title{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:500;color:#9ca3af}.minimap-icon{font-size:14px}.minimap-energy{display:none}.minimap-grid{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px;background:#0000004d;border-radius:10px}.minimap-row{display:flex;gap:2px}.minimap-cell{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:12px;border-radius:5px;background:transparent}.minimap-cell.has-room{background:#ffffff0d;border:1px solid rgba(255,255,255,.1)}.minimap-cell.has-room.explored{background:#ffffff1a;border-color:#fff3}.minimap-cell.has-room:not(.explored){background:#0006;color:#6b7280}.minimap-cell.current{background:color-mix(in srgb,var(--color-highlight) 30%,transparent);border-color:var(--color-highlight);box-shadow:0 0 8px color-mix(in srgb,var(--color-highlight) 50%,transparent);animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 8px color-mix(in srgb,var(--color-highlight) 30%,transparent)}50%{box-shadow:0 0 16px color-mix(in srgb,var(--color-highlight) 60%,transparent)}}.minimap-legend{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:10px;color:#6b7280}.combat-alert{color:#f87171;font-weight:600;animation:blink 1s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.ws-status{font-size:10px;padding:2px 8px;border-radius:10px}.ws-status.connected{color:#4ade80;background:#4ade801a}.ws-status.disconnected{color:#f87171;background:#f871711a}.import-modal{width:90%;max-width:500px;max-height:80vh;overflow-y:auto}.import-form .modal-input{width:100%;padding:1rem;background:#1a1a2e;border:none;border-radius:12px;color:#fff;font-size:1rem;margin-bottom:1rem;box-sizing:border-box}.import-form .modal-input:focus{outline:2px solid #e94560}.import-form .modal-input::placeholder{color:#666}.import-form .primary-btn{background:#e94560;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:background .2s;width:100%}.import-form .primary-btn:hover:not(:disabled){background:#d63850}.import-form .primary-btn:disabled{opacity:.6;cursor:not-allowed}.import-results .secondary-btn{background:transparent;color:#e94560;border:1px solid #e94560;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s;width:100%}.import-results .secondary-btn:hover{background:#e945601a}.import-instructions{background:#1a1a2e;padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.9rem}.import-instructions p{margin:0 0 .75rem;color:#ccc}.import-instructions ol{margin:0;padding-left:1.25rem;color:#aaa}.import-instructions li{margin-bottom:.5rem}.import-instructions a{color:#e94560;text-decoration:none}.import-instructions a:hover{text-decoration:underline}.import-form .form-group{margin-bottom:1rem}.import-form label{display:block;font-size:.85rem;color:#888;margin-bottom:.5rem}.import-options{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.import-option{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:#ccc;font-size:.9rem}.import-option input[type=checkbox]{width:18px;height:18px;accent-color:#e94560}.import-error{background:#f4433633;color:#f44336;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.import-results{padding-top:.5rem}.import-summary{display:flex;gap:1.5rem;justify-content:center;margin-bottom:1.5rem}.summary-stat{text-align:center;padding:1rem 1.5rem;background:#1a1a2e;border-radius:8px;min-width:100px}.summary-stat.success{border:2px solid #4caf50}.summary-stat.skipped{border:2px solid #ff9800}.stat-value{display:block;font-size:2rem;font-weight:700;color:#fff}.stat-label{font-size:.85rem;color:#888}.imported-tasks-list{margin-bottom:1rem}.imported-tasks-list h4{margin:0 0 .75rem;font-size:.9rem;color:#888}.tasks-scroll{max-height:200px;overflow-y:auto;background:#1a1a2e;border-radius:8px;padding:.5rem}.imported-task{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:4px;font-size:.85rem}.imported-task.success{background:#4caf501a}.imported-task.skipped{background:#ff98001a;opacity:.7}.task-icon{flex-shrink:0}.task-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#ddd}.task-status{color:#4caf50;font-weight:700}.task-error{color:#ff9800;font-size:.75rem}.import-errors{margin-bottom:1rem}.import-errors h4{margin:0 0 .5rem;font-size:.9rem;color:#f44336}.error-item{background:#f443361a;color:#f44336;padding:.5rem;border-radius:4px;font-size:.85rem;margin-bottom:.25rem}@media(max-width:480px){.import-options{flex-direction:column;gap:.75rem}.import-summary{gap:1rem}.summary-stat{min-width:80px;padding:.75rem 1rem}.stat-value{font-size:1.5rem}}.settings-page{min-height:100vh;background:var(--color-background);color:var(--color-text)}.settings-header{display:flex;align-items:center;gap:1.5rem;padding:1rem 2rem;background:var(--color-background-secondary);border-bottom:1px solid var(--color-border)}.settings-header h1{margin:0;color:var(--color-highlight);font-size:1.5rem}.back-btn{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s}.back-btn:hover{border-color:var(--color-highlight);color:var(--color-highlight)}.settings-content{max-width:800px;margin:0 auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.settings-section{background:var(--color-background-secondary);border-radius:16px;padding:1.5rem}.settings-section h2{margin:0 0 .5rem;font-size:1.25rem;color:var(--color-text)}.section-description{color:var(--color-text-muted);font-size:.9rem;margin:0 0 1.5rem}.account-info{margin-bottom:2rem;padding:1rem;background:var(--color-background);border-radius:12px}.info-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid #2a2a4e}.info-row:last-child{border-bottom:none}.info-label{color:var(--color-text-muted);font-size:.9rem}.info-value{color:var(--color-text);font-weight:500}.password-change h3{margin:0 0 1rem;font-size:1rem;color:var(--color-text)}.settings-input{width:100%;padding:1rem;background:var(--color-background);border:none;border-radius:12px;color:var(--color-text);font-size:1rem;margin-bottom:1rem;box-sizing:border-box}.settings-input:focus{outline:2px solid var(--color-highlight)}.settings-input::placeholder{color:#666}.error-message{color:var(--color-error);font-size:.875rem;margin:0 0 1rem}.success-message{color:var(--color-success);font-size:.875rem;margin:0 0 1rem}.primary-btn{background:var(--color-button);color:var(--color-text);border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:background .2s}.primary-btn:hover:not(:disabled){background:var(--color-button-hover)}.primary-btn:disabled{opacity:.6;cursor:not-allowed}.secondary-btn{background:transparent;color:var(--color-button);border:1px solid var(--color-button);padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s}.secondary-btn:hover:not(:disabled){background:#e945601a}.secondary-btn:disabled{opacity:.5;cursor:not-allowed}.notification{position:fixed;top:1rem;right:1rem;background:var(--color-success);color:var(--color-text);padding:1rem 1.5rem;border-radius:8px;z-index:1000;animation:slideIn .3s ease-out}.theme-controls{display:flex;flex-direction:column;gap:1.25rem}.color-setting{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--color-background);border-radius:12px}.color-setting label{display:flex;flex-direction:column;gap:.25rem}.color-label{font-weight:500;color:var(--color-text)}.color-value{font-size:.8rem;color:var(--color-text-muted);font-family:monospace;text-transform:uppercase}.color-input-wrapper{display:flex;align-items:center;gap:.75rem}.color-input{width:50px;height:40px;padding:0;border:none;border-radius:8px;cursor:pointer;background:transparent}.color-input::-webkit-color-swatch-wrapper{padding:0}.color-input::-webkit-color-swatch{border:2px solid rgba(255,255,255,.2);border-radius:6px}.color-input::-moz-color-swatch{border:2px solid rgba(255,255,255,.2);border-radius:6px}.color-preview{width:40px;height:40px;border-radius:8px;border:2px solid rgba(255,255,255,.2)}.theme-actions{display:flex;justify-content:flex-end;padding-top:.5rem}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:768px){.settings-header{padding:.75rem 1rem;gap:1rem}.settings-header h1{font-size:1.25rem}.settings-content{padding:1rem;gap:1rem}.back-btn{padding:.4rem .75rem;font-size:.85rem}.settings-section{padding:1rem}}@media(max-width:480px){.settings-header{flex-direction:column;align-items:flex-start;gap:.75rem}.info-row{flex-direction:column;gap:.25rem}.color-setting{flex-direction:column;align-items:flex-start;gap:.75rem}.color-input-wrapper{width:100%;justify-content:flex-end}}.loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#1a1a2e;color:#fff;font-size:1.5rem}
