:root{color-scheme:light;font-family:Trebuchet MS,Segoe UI,sans-serif;line-height:1.5;font-weight:400;background:radial-gradient(circle at top,rgba(231,224,195,.95),transparent 40%),linear-gradient(180deg,#f6f1df,#ece4cc);color:#2b2418}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}a{color:inherit}button,input,textarea,select{font:inherit}#root{min-height:100vh}.page-shell{width:min(1180px,calc(100% - 2rem));margin:0 auto;padding:2rem 0 3rem}.page-header{display:flex;flex-direction:column;gap:.5rem;margin-bottom:2rem}.eyebrow{margin:0;letter-spacing:.08em;text-transform:uppercase;font-size:.85rem;color:#75654a}.page-title{margin:0;font-size:clamp(2rem,5vw,3.4rem);line-height:1.05}.page-copy{margin:0;max-width:60ch;color:#594c38}.status-panel{min-height:180px;display:grid;place-items:center;text-align:center;gap:.6rem;padding:1.5rem;border:2px solid #c5b792;border-radius:20px;background:#fffbf2e6;box-shadow:0 16px 50px #523f1f1a}.status-panel h1,.status-panel h2,.status-panel p{margin:0}.character-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem}.character-card{display:grid;grid-template-rows:minmax(220px,1fr) auto;text-decoration:none;border:2px solid #cabd9e;border-radius:22px;overflow:hidden;background:#fffcf5f2;box-shadow:0 20px 40px #58441f1f;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.character-card:hover,.character-card:focus-visible{transform:translateY(-3px);border-color:#9f7e38;box-shadow:0 24px 55px #58441f2e;outline:none}.card-image-shell{display:grid;place-items:center;min-height:220px;background:linear-gradient(180deg,#fffaedf2,#ede2c3f2);padding:1rem}.card-image,.detail-preview-image,.projectile-image{display:block;max-width:100%;height:auto}.card-copy{padding:1rem 1.1rem 1.2rem}.card-title{margin:0;font-size:1.1rem}.card-subtitle{margin:.35rem 0 0;color:#66573f}.detail-layout{display:grid;gap:2rem}.detail-topbar{display:flex;justify-content:flex-start}.text-link{color:#684d15;text-decoration-thickness:2px;text-underline-offset:3px}.detail-hero{display:grid;grid-template-columns:minmax(0,340px) minmax(0,1fr);gap:1.5rem;align-items:start}.detail-preview-shell,.projectile-list,.animation-panel{border:2px solid #cabd9e;border-radius:24px;background:#fffcf5f2;box-shadow:0 18px 45px #58441f1a}.detail-preview-shell{min-height:360px;display:grid;place-items:center;padding:1.5rem}.section-stack{display:grid;gap:1rem}.section-heading{margin:0;font-size:1.55rem}.projectile-list{padding:1rem;min-height:160px}.projectile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}.projectile-card{border:1px solid #d9cfb8;border-radius:16px;padding:.9rem;background:#fffaf0;min-height:150px;display:grid;gap:.7rem}.projectile-figure{margin:0;min-height:88px;display:grid;place-items:center}.projectile-name{margin:0;font-weight:700}.animations-list{display:grid;gap:1rem}.animation-panel{padding:1rem}.animation-heading{margin:0 0 .75rem;font-size:1.15rem}.animation-player-shell{min-height:240px;border:1px solid #d7c9a7;border-radius:18px;overflow:hidden;display:grid;place-items:center;background:linear-gradient(180deg,#fbf7ecf2,#e8dfc9f2)}.animation-stage{width:100%;min-height:240px;display:grid;place-items:center;padding:1rem}.animation-stage canvas{display:block;max-width:100%;height:auto;image-rendering:pixelated}.loading-state,.error-state,.empty-state{width:100%;min-height:inherit;display:grid;place-items:center;text-align:center;padding:1rem;color:#5b4a2d}.error-state{color:#8a2d2d}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(max-width:820px){.detail-hero{grid-template-columns:1fr}.page-shell{width:min(100% - 1.2rem,1180px);padding-top:1.25rem}}
