:root{--bg:#0f1114;--surface:#171a1f;--surface-muted:#111419;--border:#272c34;--border-strong:#3a404b;--text:#f3f4f6;--muted:#9aa2ad;--muted-soft:#6f7783;--error-bg:#2b1b1e;--error-border:#5c2a33;--error-text:#f0b4be;--mono:"SFMono-Regular", "IBM Plex Mono", "Cascadia Code", Consolas, monospace;color:var(--text);background:var(--bg);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Avenir Next,Segoe UI Variable Text,Segoe UI,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html{min-height:100%}body{background:var(--bg);min-height:100vh;color:var(--text);margin:0}button,input,code,pre{font:inherit}code,pre{font-family:var(--mono)}a{color:inherit}h1,h2,h3,p{margin:0}#root{min-height:100svh}.app-shell{min-height:100svh;padding:20px}.page{gap:16px;width:min(1120px,100%);margin:0 auto;display:grid}.surface-card{border:1px solid var(--border);background:var(--surface);border-radius:16px}.search-panel,.player-strip,.equipment-section{padding:14px}.search-form{gap:12px;display:flex}.tag-field{border:1px solid var(--border-strong);background:var(--surface-muted);border-radius:12px;flex:1;align-items:center;gap:10px;min-height:48px;padding:0 14px;display:flex}.tag-field:focus-within{border-color:var(--text)}.tag-prefix,.battle-opponent,.meta-chip{font-family:var(--mono)}.tag-prefix{color:var(--muted)}.tag-field input{min-width:0;color:var(--text);background:0 0;border:0;outline:0;flex:1}.tag-field input::placeholder{color:var(--muted-soft)}.search-button{border:1px solid var(--text);background:var(--text);min-width:104px;min-height:48px;color:var(--bg);cursor:pointer;border-radius:12px;padding:0 16px;font-weight:600}.search-button:disabled{cursor:not-allowed;opacity:.55}.status-message{border:1px solid var(--error-border);background:var(--error-bg);color:var(--error-text);border-radius:12px;margin:0;padding:12px 14px}.results{gap:16px;display:grid}.player-strip{align-content:start;gap:12px;display:grid}.player-heading strong{font-size:1.1rem;font-weight:650;display:block}.meta-list,.equipment-list,.battle-metrics,.loot-list{flex-wrap:wrap;align-items:flex-start;gap:8px;display:flex}.meta-chip,.equipment-chip,.metric-chip,.loot-chip{border:1px solid var(--border);border-radius:999px;align-items:center;display:inline-flex}.meta-chip,.metric-chip,.loot-chip{background:var(--surface-muted);color:var(--muted);padding:5px 10px;font-size:.86rem}.metric-chip-stars{align-items:center;gap:4px;display:inline-flex}.star-icon{width:.9rem;height:.9rem;fill:var(--muted-soft)}.star-icon.is-filled{fill:#f2c14e}.equipment-section{align-content:start;gap:12px;display:grid}.section-heading,.battle-column-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.section-heading h2,.battle-column-header h3{margin:0;font-size:.95rem;font-weight:600}.section-heading span,.battle-column-header span{color:var(--muted);font-size:.88rem}.equipment-chip{background:var(--surface-muted);align-items:center;gap:10px;padding:8px 12px;display:inline-flex}.equipment-chip span{color:var(--text)}.equipment-chip strong{color:var(--muted);font-size:.88rem}.battle-board{gap:12px;display:grid}.battle-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.battle-column{border:1px solid var(--border);background:var(--surface);border-radius:16px;overflow:hidden}.battle-column-header{border-bottom:1px solid var(--border);padding:12px 14px}.battle-scroll{align-content:start;align-items:start;gap:10px;height:360px;padding:12px;display:grid;overflow:auto}.battle-scroll::-webkit-scrollbar{width:10px}.battle-scroll::-webkit-scrollbar-thumb{border:2px solid var(--surface);background:var(--border-strong);border-radius:999px}.battle-card{border:1px solid var(--border);background:var(--surface-muted);border-radius:12px;gap:10px;padding:12px;display:grid}.battle-card-top{justify-content:space-between;align-items:start;gap:12px;display:flex}.battle-opponent-block{gap:2px;display:grid}.battle-side-meta{flex-shrink:0;justify-items:end;gap:4px;display:grid}.battle-opponent-name{color:var(--text);font-size:.92rem;font-weight:600;line-height:1.25}.battle-opponent{color:var(--muted);font-size:.82rem}.battle-observed-at{color:var(--muted);cursor:help;white-space:nowrap;font-size:.72rem;line-height:1;transform:translateY(8px)}.battle-resource-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.army-link{width:fit-content;color:var(--muted);border-bottom:1px solid var(--border-strong);white-space:nowrap;margin-left:auto;font-size:.8rem;text-decoration:none}.army-link:hover{color:var(--text);border-color:var(--muted)}.empty-state{color:var(--muted);margin:0;font-size:.92rem}@media (width<=720px){.app-shell{padding:14px}.search-form,.battle-row{grid-template-columns:1fr}.search-form{display:grid}.search-button{width:100%}.battle-scroll{height:300px}.battle-card-top{flex-direction:column;gap:8px}.battle-side-meta{justify-content:space-between;align-items:center;gap:8px;width:100%;display:flex}.battle-observed-at{transform:none}.battle-resource-row{align-items:flex-start;gap:8px}.loot-list{flex:1;min-width:0}.army-link{align-self:flex-end;margin-left:0}}
