/* Siege — Async Word Combat */

.hero-back-link{display:inline-block;margin-bottom:.5rem;color:var(--muted);text-decoration:none;font-size:1.1rem}
.hero-back-link:hover{color:var(--ink)}
.hero-copy-wrap{display:flex;flex-direction:column}

/* Lobby */
.lobby-panel{padding:1.5rem}
.lobby-panel h2{margin:0 0 .3rem;font-size:1.5rem}
.lobby-desc{margin:0 0 1.2rem;color:var(--muted);line-height:1.5;max-width:34rem}
.lobby-actions{display:flex;gap:.8rem;align-items:center;flex-wrap:wrap;margin-bottom:1.2rem}
.join-row{display:flex;gap:.4rem}
.join-input{width:8rem;padding:.55rem .7rem;border:2px solid var(--line-strong);border-radius:var(--radius);background:rgba(255,255,255,.04);font:inherit;font-family:var(--mono);font-size:.95rem;color:var(--ink);text-transform:uppercase;letter-spacing:.1em;text-align:center}
.join-input:focus{border-color:var(--accent);outline:none}

/* My Games list */
.my-games{margin-top:.5rem}
.my-games h3{margin:0 0 .5rem;font-size:.9rem;color:var(--muted)}
.mg-row{display:grid;grid-template-columns:1fr auto auto;gap:.5rem;align-items:center;padding:.5rem .4rem;border-bottom:1px solid var(--line)}
.mg-row:last-child{border-bottom:none}
.mg-info{font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mg-status{font-family:var(--mono);font-size:.72rem;padding:.2rem .5rem;border-radius:999px}
.mg-status.your-turn{background:rgba(199,210,254,.12);color:var(--accent)}
.mg-status.waiting{background:rgba(255,255,255,.05);color:var(--muted)}
.mg-status.finished{background:rgba(255,255,255,.03);color:var(--muted)}
.mg-open{font-size:.8rem}

/* Siege layout */
.siege-layout{padding:1.2rem;display:flex;flex-direction:column;gap:.8rem}

/* Fortresses */
.fortress-row{display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;align-items:center}
.fortress{text-align:center}
.fortress-label{display:block;font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.3rem}
.fortress-hp-bar{height:.7rem;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}
.fortress-hp-fill{height:100%;border-radius:999px;transition:width .5s ease;background:linear-gradient(90deg,#7070e0,#5050c0)}
.fortress-hp-fill.opp{background:linear-gradient(90deg,#e07070,#c05050)}
.fortress-hp-val{display:block;font-family:var(--mono);font-size:1.4rem;font-weight:700;margin-top:.2rem}
.fortress-shield{display:inline-block;margin-top:.2rem;padding:.15rem .45rem;border-radius:999px;background:rgba(199,210,254,.12);font-family:var(--mono);font-size:.7rem;color:var(--accent)}
.vs-badge{font-family:var(--mono);font-size:.8rem;color:var(--muted);letter-spacing:.1em}

/* Turn info */
.turn-info{display:flex;justify-content:space-between;align-items:center;padding:.4rem .6rem;border-radius:var(--radius);background:rgba(255,255,255,.03);border:2px solid var(--line)}
.turn-info .turn-num{font-family:var(--mono);font-size:.75rem;color:var(--muted)}
#turnLabel{font-weight:600;font-size:.9rem}

/* Letter rack */
.rack-area{display:flex;justify-content:center}
.letter-rack{display:flex;gap:.35rem;justify-content:center;flex-wrap:wrap}
.rack-tile{width:3rem;height:3.2rem;display:flex;align-items:center;justify-content:center;border:2px solid var(--line-strong);border-radius:var(--radius);background:rgba(255,255,255,.05);font-family:var(--mono);font-size:1.4rem;font-weight:700;color:var(--ink);cursor:pointer;transition:transform .1s ease,border-color .15s ease;user-select:none}
.rack-tile:hover{border-color:var(--accent);transform:scale(1.06)}
.rack-tile.used{opacity:.25;pointer-events:none;transform:scale(0.9)}
.rack-tile.rare{color:#e0a020;border-color:rgba(224,160,32,.3)}

/* Word builder */
.word-builder{text-align:center}
.word-display{min-height:3.2rem;display:flex;gap:.25rem;justify-content:center;align-items:center;padding:.4rem .8rem;border:2px solid var(--line-strong);border-radius:var(--radius);background:rgba(255,255,255,.03)}
.word-placeholder{color:var(--muted);font-size:.85rem}
.word-letter{display:inline-flex;align-items:center;justify-content:center;width:2.4rem;height:2.6rem;border-radius:var(--radius);background:var(--accent-soft);font-family:var(--mono);font-size:1.2rem;font-weight:700;color:var(--accent-strong);cursor:pointer;transition:transform .1s ease}
.word-letter:hover{transform:scale(1.08);background:rgba(243,181,176,.15);color:var(--danger)}
.word-meta{margin-top:.3rem;display:flex;gap:.8rem;justify-content:center}
.word-damage{font-family:var(--mono);font-size:1rem;font-weight:700;color:var(--danger)}
.word-bonuses{font-size:.78rem;color:var(--success)}

/* Controls */
.siege-controls{display:flex;gap:.5rem;justify-content:center}
.siege-controls button{min-width:120px}

/* Power-ups */
.power-up-row{display:flex;gap:.4rem;align-items:center;justify-content:center;flex-wrap:wrap;padding:.5rem;border:2px solid var(--accent-soft);border-radius:var(--radius);background:rgba(199,210,254,.04)}
.pu-label{font-size:.78rem;color:var(--accent);font-weight:600}
.pu-btn{font-size:.72rem!important;min-height:1.8rem!important;padding:.2rem .5rem!important}
.pu-btn.active{border-color:var(--accent)!important;background:var(--accent-soft)!important;color:var(--accent-strong)!important}

/* Move history */
.move-history{max-height:200px;overflow-y:auto;border:2px solid var(--line);border-radius:var(--radius);background:rgba(0,0,0,.2)}
.move-row{display:grid;grid-template-columns:auto 1fr auto;gap:.5rem;align-items:center;padding:.35rem .5rem;border-bottom:1px solid var(--line);font-size:.8rem}
.move-row:last-child{border-bottom:none}
.move-turn{font-family:var(--mono);font-size:.7rem;color:var(--muted)}
.move-word{font-family:var(--mono);font-weight:700;text-transform:uppercase}
.move-dmg{font-family:var(--mono);color:var(--danger);font-weight:600}
.move-heal{color:var(--success)}
.move-empty{text-align:center;padding:1rem;color:var(--muted);font-size:.85rem}

/* Game Over */
.game-over-panel{padding:2rem;text-align:center}
.game-over-panel h2{margin:0 0 1rem;font-size:2rem}
.game-over-stats{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;max-width:280px;margin:0 auto 1.2rem}
.result-stat{padding:.6rem;border:2px solid var(--line);border-radius:var(--radius);background:rgba(255,255,255,.03)}
.result-stat-label{display:block;color:var(--muted);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em}
.result-stat-value{display:block;margin-top:.15rem;font-size:1.2rem;font-weight:700}

@media(max-width:720px){
  .fortress-row{gap:.5rem}
  .fortress-hp-val{font-size:1.1rem}
  .rack-tile{width:2.5rem;height:2.8rem;font-size:1.2rem}
  .word-letter{width:2rem;height:2.2rem;font-size:1rem}
}
