.login-container{background:linear-gradient(135deg,#0a0e17 0%,#1a1a3e 50%,#0a0e17 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:16px;width:100%;max-width:420px;padding:40px;box-shadow:0 20px 60px #00000080}.login-title{text-align:center;background:linear-gradient(135deg, var(--color-primary), var(--color-accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:4px;font-size:2rem}.login-subtitle{text-align:center;color:var(--color-text-secondary);margin-bottom:24px;font-size:.9rem}.login-tabs{background:var(--color-bg);border-radius:var(--radius);gap:4px;margin-bottom:24px;padding:4px;display:flex}.login-tab{color:var(--color-text-secondary);background:0 0;border:none;border-radius:6px;flex:1;padding:10px;font-weight:500;transition:all .2s}.login-tab.active{background:var(--color-primary);color:#fff}.login-form{flex-direction:column;gap:12px;display:flex}.login-input{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);padding:12px 16px;font-size:.95rem;transition:border-color .2s}.login-input:focus{border-color:var(--color-primary);outline:none}.login-button{border-radius:var(--radius);background:linear-gradient(135deg, var(--color-primary), #7c3aed);color:#fff;border:none;margin-top:8px;padding:12px;font-size:1rem;font-weight:600;transition:opacity .2s}.login-button:hover{opacity:.9}.login-error{color:var(--color-danger);text-align:center;font-size:.85rem}.quick-login{border-top:1px solid var(--color-border);text-align:center;margin-top:32px;padding-top:24px}.quick-login-title{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:16px;font-size:.8rem;font-weight:700}.quick-login-buttons{justify-content:center;gap:12px;display:flex}.quick-btn{border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;background:#ffffff08;border-radius:12px;flex:1;padding:10px;font-size:.85rem;font-weight:600;transition:all .2s}.quick-btn:hover{border-color:var(--color-primary);background:#ffffff14;transform:translateY(-2px)}.quick-login-tip{color:var(--color-text-secondary);margin-top:16px;font-size:.75rem;line-height:1.4}.quick-login-tip strong{color:var(--color-primary)}.lobby-container{max-width:900px;margin:0 auto;padding:24px}.lobby-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;margin-bottom:40px;padding-bottom:16px;display:flex}.lobby-header h1{font-size:1.5rem}.lobby-user-info{align-items:center;gap:16px;display:flex}.lobby-gold{color:var(--color-accent);font-weight:600}.lobby-username{color:var(--color-text-secondary)}.lobby-logout{border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-secondary);background:0 0;padding:6px 14px;font-size:.85rem;transition:all .2s}.lobby-logout:hover{border-color:var(--color-danger);color:var(--color-danger)}.lobby-combat{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:16px;margin-bottom:40px;padding:24px}.lobby-section-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.lobby-section-header h2{color:var(--color-text);font-size:1.25rem}.lobby-combat-actions{gap:12px;display:flex}.lobby-btn{border-radius:var(--radius);cursor:pointer;padding:8px 16px;font-size:.9rem;font-weight:600;transition:all .2s}.lobby-btn.action{background:var(--color-primary);color:#fff;border:none}.lobby-btn.secondary{border:1px solid var(--color-border);color:var(--color-text-secondary);background:0 0}.lobby-btn:hover{opacity:.9;transform:translateY(-1px)}.rooms-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px;display:grid}.room-card{border:1px solid var(--color-border);background:#ffffff08;border-radius:12px;justify-content:space-between;align-items:center;padding:16px;transition:border-color .2s;display:flex}.room-card:hover{border-color:var(--color-primary)}.room-info{flex-direction:column;gap:4px;display:flex}.room-host{color:var(--color-text);font-weight:600}.room-date{color:var(--color-text-secondary);font-size:.75rem}.room-join-btn{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:6px 12px;font-size:.8rem;font-weight:600}.room-join-btn:disabled{background:var(--color-border);cursor:not-allowed}.no-rooms{text-align:center;color:var(--color-text-secondary);background:#ffffff03;border-radius:12px;grid-column:1/-1;padding:32px;font-style:italic}.lobby-nav{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.lobby-nav-card{background:var(--color-bg-card);border:1px solid var(--color-border);color:var(--color-text);border-radius:12px;flex-direction:column;align-items:center;gap:8px;padding:24px;transition:all .2s;display:flex}.lobby-nav-card:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 8px 25px #6366f126}.lobby-nav-icon{font-size:2rem}.lobby-nav-title{font-size:1rem;font-weight:600}.lobby-nav-desc{color:var(--color-text-secondary);text-align:center;font-size:.75rem}.farming-hud{z-index:100;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#1a2332e6;border:2px solid #6366f1;border-radius:12px;flex-direction:column;align-items:center;gap:10px;padding:15px 25px;display:flex;position:absolute;top:20px;left:50%;transform:translate(-50%);box-shadow:0 4px 15px #00000080}.hud-top .round-badge{color:#f59e0b;text-transform:uppercase;letter-spacing:1px;font-size:1.2rem;font-weight:700}.pips-container{justify-content:center;gap:8px;display:flex}.pip{border:2px solid #6366f1;border-radius:50%;width:16px;height:16px;transition:all .3s}.pip.filled{background:#10b981;border-color:#10b981;box-shadow:0 0 8px #10b981}.pip.empty{background:0 0}.pips-label{color:#aaa;text-align:center;margin-top:5px;font-size:.85rem}.end-phase-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;border-radius:6px;margin-top:5px;padding:8px 16px;font-weight:700;transition:transform .2s,box-shadow .2s}.end-phase-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #6366f166}.end-phase-btn:active{transform:translateY(0)}.resource-map-container{background:#0a0e17;flex-direction:column;height:100vh;display:flex}.resource-map-header{background:#1a2332;border-bottom:1px solid #2d3748;align-items:center;gap:16px;padding:12px 24px;display:flex}.resource-map-header h2{color:#e2e8f0;margin:0;font-size:1.2rem}.back-button{color:#e2e8f0;cursor:pointer;background:0 0;border:1px solid #2d3748;border-radius:8px;padding:6px 12px;font-size:.85rem;transition:border-color .2s}.back-button:hover{border-color:#6366f1}.seed-badge{color:#a5b4fc;white-space:nowrap;background:#6366f126;border:1px solid #6366f14d;border-radius:6px;padding:4px 12px;font-size:.8rem;font-weight:500}.map-legend{gap:10px;margin-left:auto;font-size:.75rem;display:flex}.legend-item{color:#94a3b8;align-items:center;gap:4px;display:flex}.legend-item:before{content:"";border-radius:2px;width:10px;height:10px;display:inline-block}.legend-ground:before{background:#374151}.legend-iron:before{background:#78716c}.legend-leather:before{background:#92400e}.legend-crystal:before{background:#7c3aed}.legend-fabric:before{background:#a855f7}.legend-wood:before{background:#166534}.legend-herb:before{background:#4ade80}.legend-gold:before{background:#eab308}.resource-map-canvas{flex:1;position:relative}.map-loading,.map-error{color:#94a3b8;font-size:1.1rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.map-error{color:#ef4444}.tile-info-panel{z-index:100;pointer-events:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172aeb;border:1px solid #334155;border-radius:10px;min-width:180px;max-width:260px;padding:14px 18px;transition:opacity .15s;position:absolute;bottom:16px;left:16px;box-shadow:0 4px 20px #00000073}.tile-info-title{color:#f1f5f9;margin-bottom:2px;font-size:.95rem;font-weight:600}.tile-info-coords{color:#64748b;margin-bottom:8px;font-size:.72rem}.tile-info-props{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.tile-info-props li{color:#94a3b8;padding-left:14px;font-size:.8rem;position:relative}.tile-info-props li:before{content:"•";color:#6366f1;position:absolute;left:0}.tile-info-empty{color:#475569;font-size:.82rem;font-style:italic}.tile-info-distance{color:#6366f1;margin-top:8px;font-size:.78rem;font-weight:500}.tile-info-blocked{color:#ef4444;margin-top:8px;font-size:.78rem;font-weight:500}.shop-container{max-width:900px;margin:0 auto;padding:24px}.shop-header{border-bottom:1px solid var(--color-border);align-items:center;gap:16px;margin-bottom:24px;padding-bottom:16px;display:flex}.shop-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.shop-loading{color:var(--color-text-secondary);text-align:center;grid-column:1/-1}.shop-item-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;flex-direction:column;gap:8px;padding:20px;transition:border-color .2s;display:flex}.shop-item-card:hover{border-color:var(--color-accent)}.shop-item-type{color:var(--color-primary);text-transform:uppercase;font-size:.75rem;font-weight:600}.shop-item-name{font-size:1rem}.shop-item-price{color:var(--color-accent);font-weight:600}.shop-buy-button{border-radius:var(--radius);background:var(--color-primary);color:#fff;border:none;margin-top:8px;padding:8px;font-weight:500;transition:opacity .2s}.shop-buy-button:hover{opacity:.85}.inventory-container{max-width:700px;margin:0 auto;padding:24px}.inventory-header{border-bottom:1px solid var(--color-border);align-items:center;gap:16px;margin-bottom:24px;padding-bottom:16px;display:flex}.inventory-loading{color:var(--color-text-secondary);text-align:center}.inventory-list{flex-direction:column;gap:8px;display:flex}.inventory-item{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:16px;transition:border-color .2s;display:flex}.inventory-item.equipped{border-color:var(--color-success);background:#10b9810d}.inventory-item-info{align-items:center;gap:12px;display:flex}.inventory-item-name{font-weight:500}.inventory-item-type{color:var(--color-primary);text-transform:uppercase;background:#6366f11a;border-radius:4px;padding:2px 8px;font-size:.75rem}.inventory-item-qty{color:var(--color-text-secondary);font-size:.85rem}.inventory-equip-btn{border-radius:var(--radius);border:none;padding:6px 16px;font-size:.85rem;font-weight:500;transition:opacity .2s}.inventory-equip-btn.equip{background:var(--color-primary);color:#fff}.inventory-equip-btn.unequip{border:1px solid var(--color-border);color:var(--color-text-secondary);background:0 0}.inventory-equip-btn:hover{opacity:.85}.combat-hud{-webkit-backdrop-filter:blur(12px)saturate(180%);z-index:100;background:#0f172acc;border:1px solid #ffffff1a;border-radius:24px;justify-content:space-between;align-items:center;gap:32px;width:90%;max-width:1000px;padding:20px 32px;display:flex;position:absolute;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 25px 50px -12px #00000080}.hud-stats{flex-direction:column;gap:12px;min-width:240px;display:flex}.hud-hp{flex-direction:column;gap:4px;display:flex}.hud-hp-header{justify-content:space-between;align-items:center;display:flex}.hud-label{color:#94a3b8;letter-spacing:.05em;text-transform:uppercase;font-size:.75rem;font-weight:700}.hud-bar{background:#0000004d;border:1px solid #ffffff0d;border-radius:999px;width:100%;height:10px;overflow:hidden}.hud-bar-fill.hp{background:linear-gradient(90deg,#ef4444 0%,#f87171 100%);box-shadow:0 0 10px #ef444480}.hud-value{color:#f1f5f9;font-family:Inter,sans-serif;font-size:.85rem;font-weight:600}.hud-points{gap:20px;display:flex}.hud-pa,.hud-pm{background:#ffffff0d;border-radius:8px;align-items:center;gap:6px;padding:4px 12px;font-size:.9rem;font-weight:700;display:flex}.hud-pa{color:#fbbf24;border:1px solid #fbbf2433}.hud-pm{color:#60a5fa;border:1px solid #60a5fa33}.hud-selected-spell-info{color:#f1f5f9;text-align:center;white-space:nowrap;opacity:0;pointer-events:none;background:#0f172ae6;border:1px solid #6366f1;border-radius:12px;padding:8px 16px;font-size:.8rem;animation:.3s forwards fadeIn;position:absolute;top:-50px;left:50%;transform:translate(-50%)}@keyframes fadeIn{to{opacity:1;top:-60px}}.hud-hint{color:#94a3b8;margin:0;font-size:.7rem}.hud-spells{justify-content:center;gap:12px;display:flex}.hud-spell-btn{color:#f8fafc;cursor:pointer;background:#1e293b99;border:2px solid #ffffff1a;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:2px;width:70px;height:70px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.hud-spell-btn:after{content:"";pointer-events:none;background:linear-gradient(135deg,#ffffff1a,#0000);position:absolute;inset:0}.hud-spell-btn:hover:not(.disabled){border-color:#6366f1;transform:translateY(-4px)scale(1.05);box-shadow:0 10px 20px -5px #6366f166}.hud-spell-btn.active{background:#6366f14d;border-color:#818cf8;box-shadow:inset 0 0 15px #6366f180}.hud-spell-btn.disabled{filter:grayscale();opacity:.5;cursor:not-allowed}.spell-name{text-align:center;max-width:90%;font-size:.7rem;font-weight:700;line-height:1.1}.spell-cost{color:#fbbf24;font-size:.65rem;font-weight:800}.spell-cooldown{color:#f87171;z-index:10;background:#000000b3;justify-content:center;align-items:center;font-size:1.5rem;font-weight:900;display:flex;position:absolute;inset:0}.hud-actions{flex-direction:column;align-items:flex-end;gap:12px;min-width:200px;display:flex}.hud-logs{background:#0006;border-radius:12px;flex-direction:column;gap:4px;width:100%;height:80px;padding:8px;font-family:Courier New,Courier,monospace;font-size:.75rem;display:flex;overflow-y:auto}.hud-log{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.hud-log.damage{color:#f87171;font-weight:700}.hud-log.info{color:#94a3b8}.hud-log.victory{color:#facc15;font-weight:700}.hud-actions-right{flex-direction:column;gap:8px;width:100%;display:flex}.hud-turn-indicator{letter-spacing:.05em;text-transform:uppercase;color:#f87171;background:#ef44441a;border:1px solid #f8717133;border-radius:999px;padding:4px 12px;font-size:.75rem;font-weight:800}.hud-turn-indicator.my-turn{color:#4ade80;background:#22c55e1a;border:1px solid #4ade8033;animation:2s infinite pulse}@keyframes pulse{0%{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}to{opacity:.8;transform:scale(1)}}.hud-end-turn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#4f46e5 0%,#3730a3 100%);border:none;border-radius:12px;width:100%;padding:10px;font-size:.85rem;font-weight:700;transition:all .3s;box-shadow:0 4px 12px #4f46e54d}.hud-end-turn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #4f46e566}.hud-end-turn:disabled{box-shadow:none;opacity:.5;cursor:not-allowed;background:#334155}.combat-container{flex-direction:column;height:100vh;display:flex}.combat-header{background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);align-items:center;gap:16px;padding:12px 24px;display:flex}.combat-turn{color:var(--color-accent);margin-left:auto;font-weight:600}.combat-arena{flex:1;position:relative}.combat-overlay{background:var(--color-bg);z-index:100;flex-direction:column;justify-content:center;align-items:center;gap:20px;display:flex;position:absolute;inset:0}.loading-spinner{border:5px solid #ffffff1a;border-top-color:var(--color-primary);border-radius:50%;width:50px;height:50px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.debug-container{max-width:1100px;margin:0 auto;padding:24px}.debug-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:16px;display:flex}.debug-header h1{font-size:1.5rem}.debug-user-badge{color:var(--color-text-secondary);background:var(--color-bg-card);border-radius:var(--radius);border:1px solid var(--color-border);align-items:center;gap:12px;padding:8px 16px;font-size:.85rem;display:flex}.debug-user-badge code{color:var(--color-primary);font-size:.75rem}.debug-grid{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px;display:grid}.debug-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:20px}.debug-card h2{border-bottom:1px solid var(--color-border);margin-bottom:16px;padding-bottom:8px;font-size:1.1rem}.debug-card p{color:var(--color-text-secondary);margin-bottom:12px;font-size:.85rem}.debug-actions{flex-wrap:wrap;gap:8px;display:flex}.debug-btn{border-radius:var(--radius);cursor:pointer;border:none;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .2s}.debug-btn.primary{background:var(--color-primary);color:#fff}.debug-btn.secondary{border:1px solid var(--color-border);color:var(--color-text-secondary);background:0 0}.debug-btn.success{background:var(--color-success);color:#fff}.debug-btn.danger{background:var(--color-danger);color:#fff}.debug-btn:hover{opacity:.9;transform:translateY(-1px)}.debug-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.seed-selector{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.seed-chip{cursor:pointer;border:1px solid var(--color-border);color:var(--color-text-secondary);background:0 0;border-radius:16px;padding:4px 10px;font-size:.75rem;font-weight:600;transition:all .2s}.seed-chip.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.seed-chip:hover{border-color:var(--color-primary)}.debug-state-panel{grid-column:1/-1}.debug-json{border-radius:var(--radius);max-height:300px;color:var(--color-text-secondary);white-space:pre-wrap;word-break:break-all;background:#0000004d;padding:12px;font-family:JetBrains Mono,Fira Code,monospace;font-size:.75rem;line-height:1.5;overflow-y:auto}.debug-status{align-items:center;gap:8px;margin-bottom:8px;display:flex}.debug-status-dot{background:var(--color-danger);border-radius:50%;width:8px;height:8px}.debug-status-dot.connected{background:var(--color-success)}.back-button{border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-secondary);cursor:pointer;background:0 0;padding:6px 14px;font-size:.85rem;transition:all .2s}.back-button:hover{border-color:var(--color-primary);color:var(--color-primary)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#3f3f46;--color-bg-secondary:#52525b;--color-bg-card:#52525b;--color-primary:#6366f1;--color-primary-hover:#818cf8;--color-accent:#f59e0b;--color-text:#e2e8f0;--color-text-secondary:#94a3b8;--color-border:#2d3748;--color-success:#10b981;--color-danger:#ef4444;--color-heal:#34d399;--font-main:"Inter", system-ui, -apple-system, sans-serif;--radius:8px;--shadow:0 4px 6px -1px #0000004d}body{font-family:var(--font-main);background-color:var(--color-bg);color:var(--color-text);min-height:100vh;line-height:1.6}#root{min-height:100vh}a{color:var(--color-primary);text-decoration:none}a:hover{color:var(--color-primary-hover)}button{cursor:pointer;font-family:var(--font-main)}input,select{font-family:var(--font-main)}
