*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,sans-serif;background-color:#faf8f5;color:#1a1a1a}.app{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:1rem;gap:1rem;max-width:480px;margin:0 auto}.app h1{margin:0;font-size:1.75rem;font-weight:700}.match-header{margin:0;font-size:.9rem;color:#555}.match-roles{margin:0;font-size:.85rem;color:#666}.app__tagline{margin:.05rem 0 .5rem;font-size:.85rem;color:#f6f1ea;font-weight:600;font-style:italic;text-align:center;background:#7a6b5a;padding:.15rem .5rem;border-radius:999px;display:inline-block}.round-info{width:100%;max-width:320px;margin:.25rem 0 .75rem;padding:.5rem .75rem;border-radius:8px;background:#efe3d4;border:1px solid #d0c0ae;text-align:center;font-size:.9rem}.round-info__round{margin:0;font-weight:600}.round-info__roles{margin:.2rem 0 0;color:#555;font-size:.85rem}.howto-card{width:100%;max-width:320px}.howto-card__toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.4rem .75rem;border-radius:6px;border:1px solid #c4b8aa;background:#efe7dd;font-size:.9rem;font-weight:600;cursor:pointer}.howto-card__toggle:hover{background:#e4d8ca}.howto-card__chevron{margin-left:.5rem}.howto-card__body{margin-top:.4rem;padding:.5rem .75rem;border-radius:6px;background:#f7f1e8;font-size:.85rem;color:#4a3b2a}.howto-card__body p{margin:0 0 .25rem}.howto-card__body p:last-child{margin-bottom:0}.player-names{width:100%;max-width:320px;display:flex;gap:.5rem;justify-content:center}.player-names__field{flex:1;display:flex;flex-direction:column;gap:.15rem;font-size:.8rem}.player-names__label{color:#555}.player-names__field input{padding:.25rem .4rem;border-radius:4px;border:1px solid #bbb;font-size:.85rem}.app__subtitle{margin:0;font-size:.9rem;color:#555;text-align:center}.app__actions{display:flex;justify-content:center;gap:.5rem}.board{position:relative;width:min(95vw,260px);aspect-ratio:100 / 120;max-width:100%;border-radius:10px;overflow:hidden;box-shadow:0 2px 10px #5c4a3d1f}.board__svg{display:block;width:100%;height:100%;pointer-events:none}.board__bg{fill:#e5dfd4}.board__line{stroke:#5c4a3d;stroke-width:1.5;stroke-linecap:round}.board__node-marker{fill:#d4c8b8}.board__nodes{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.board__nodes>*{pointer-events:auto}.board__node{position:absolute;width:14%;min-width:44px;min-height:44px;height:14%;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#d4c8b8;border:2px solid transparent;cursor:pointer;font-size:1.1rem;font-weight:700;transition:background .15s,border-color .15s,box-shadow .15s;padding:0}.board__node:hover{background:#c9bcab}.board__node--selected{border-color:#5c4a3d;box-shadow:0 0 0 2px #5c4a3d}.board__node--legal{background:#b8c9a8;border-color:#6b7a5c}.board__node--legal:hover{background:#a3b894}.board__node .piece-token{width:.85em;height:.85em;min-width:22px;min-height:22px;font-size:.95rem}.piece-token{display:inline-flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;border-radius:50%;font-size:.9rem;line-height:1}.piece-token--hunter{background:#8b2d2d;color:#fff}.piece-token--prey{background:#8b6914;color:#fff}.game-hud{width:100%;max-width:280px;padding:.75rem;background:#e8e4df;border-radius:6px}.game-hud__stats{display:grid;grid-template-columns:auto 1fr;gap:.25rem 1rem;margin:0;font-size:.9rem}.game-hud__stats dt{margin:0;color:#555}.game-hud__stats dd{margin:0;font-weight:600}.game-hud__winner{margin:.5rem 0 0;font-weight:700;color:#6b2d2d}.button{padding:.5rem 1rem;font-size:1rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;background:#ccc;color:#1a1a1a}.button:hover{background:#bbb}.button--primary{background:#6b2d2d;color:#fff}.button--primary:hover{background:#5a2525}.end-summary{margin:0;padding:.75rem 1rem;background:#d4c4b0;border-radius:6px;color:#4a2d2d;width:100%;max-width:320px}.end-summary__title{margin:0 0 .25rem;font-weight:700}.end-summary__stats{margin:0;font-weight:600;font-size:.95rem}.install-card{width:100%;max-width:320px;display:flex;flex-direction:column;align-items:center;gap:.5rem}.button--secondary{background:#8b7355;color:#fff}.button--secondary:hover{background:#7a6247}.install-card__hint{margin:0;font-size:.85rem;color:#555}.between-rounds{margin:.5rem 0 0;padding:.75rem 1rem;background:#e8e4df;border-radius:6px;width:100%;max-width:320px}.between-rounds__title{margin:0 0 .25rem;font-weight:700}.between-rounds__stats{margin:0 0 .5rem;font-size:.9rem}.between-rounds__roles{margin:0 0 .5rem;font-size:.85rem;color:#4a3b2a}.match-summary{width:100%;max-width:320px;padding:.75rem 1rem;background:#e8e4df;border-radius:6px}.match-summary__title{margin:0 0 .25rem;font-size:1rem;font-weight:700}.match-summary__rounds{display:flex;gap:.75rem;margin-top:.25rem}.match-summary__round{flex:1}.match-summary__round-label{margin:0 0 .25rem;font-weight:600;font-size:.9rem}.match-summary__row{margin:0;display:flex;justify-content:space-between;font-size:.85rem}.match-summary__row-label{color:#555}.match-summary__row-value{font-weight:600}.match-summary__final{margin-top:.5rem;border-top:1px solid #ccc4b7;padding-top:.5rem}.match-summary__final-label{margin:0;font-size:.9rem;font-weight:600;color:#444}.match-summary__winner{margin:.25rem 0 0;font-weight:700;color:#6b2d2d}
