:root{font-family:IBM Plex Sans,Segoe UI,sans-serif;color:#1c1d1f;background:radial-gradient(circle at top left,#f4f4f0,#e7ecef 45%,#d9e2ec)}*{box-sizing:border-box}body{margin:0}main{min-height:100vh;padding:24px}h1,h2,h3,p{margin:0}.auth-shell,.lobby-shell,.room-shell{display:flex;flex-direction:column;gap:20px}.auth-shell{align-items:center;justify-content:center}.auth-card,.lobby-card,.video-panel,.game-panel{background:#ffffffd9;border:1px solid #c5d0db;border-radius:16px;padding:20px;box-shadow:0 8px 24px #1234}.auth-card,.lobby-card{width:min(680px,100%);display:flex;flex-direction:column;gap:14px}.lobby-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.history-card{grid-column:span 2}.top-row{display:flex;justify-content:space-between;align-items:center;gap:12px}button,input{font:inherit}button{border:1px solid #567;border-radius:10px;padding:10px 14px;background:#f0f4f8;cursor:pointer}button:disabled{opacity:.65;cursor:not-allowed}button.primary{background:#0f6a8b;color:#fff;border-color:#0f6a8b}.code-form{display:flex;gap:10px}.code-form input{flex:1;border:1px solid #8fa0af;border-radius:10px;padding:10px;text-transform:uppercase;letter-spacing:.2em;text-align:center}.room-layout{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.video-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px}.video-tile{background:#e3ebf3;border:1px dashed #7d90a3;border-radius:10px;min-height:140px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}.video-tile video{width:100%;min-height:140px;object-fit:cover;background:#111827}.video-tile span{display:block;padding:6px 8px;font-size:.85rem;color:#334155;border-top:1px solid #b5c1cd;background:#eff4f9}.controls{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px}.notice{color:#7a1b1b;background:#fde8e8;border:1px solid #f5b6b6;border-radius:8px;padding:8px 10px}.inline-error{color:#b42318;margin-top:4px}.resume-card{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid #c9d6e2;border-radius:10px;background:#edf3f8;padding:10px}.profile-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 12px}.history-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.history-item{border:1px solid #d7e0ea;border-radius:10px;background:#f7fafc;padding:10px 12px;display:flex;flex-direction:column;gap:3px}.socket-status{color:#475467;font-size:.9rem;margin-top:4px}.error-banner{border:1px solid #fda29b;background:#fef3f2;color:#b42318;border-radius:10px;padding:10px 12px;display:flex;gap:12px;align-items:center}.error-banner strong{font-size:.85rem}.error-banner button{margin-left:auto}.error-toast{position:fixed;right:20px;bottom:20px;background:#101828;color:#fff;padding:10px 12px;border-radius:8px;box-shadow:0 10px 24px #0003;z-index:50}.history-panel{margin-top:14px;border:1px solid #d7e0ea;background:#f8fafc;border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:8px}.move-list{margin:0;padding-left:18px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px 12px}.modal-backdrop{position:fixed;inset:0;background:#0f172a99;display:grid;place-items:center;padding:16px;z-index:60}.modal-card{width:min(560px,100%);background:#fff;border:1px solid #c8d2dd;border-radius:14px;padding:16px;box-shadow:0 20px 38px #0f172a3d;display:flex;flex-direction:column;gap:10px}.result-pgn{max-height:120px;overflow:auto;font-size:.9rem;background:#f8fafc;border:1px solid #d5dee8;border-radius:8px;padding:8px}.error{color:#b42318}@media(max-width:960px){.room-layout,.lobby-grid{grid-template-columns:1fr}.history-card{grid-column:span 1}.profile-stats{grid-template-columns:1fr}.resume-card{flex-direction:column;align-items:flex-start}.move-list{grid-template-columns:1fr}}
