.offside-module__D5MO1a__page{color:#111;background:#f0f4f8;padding:1.5rem 0 3rem;font-family:Segoe UI,Helvetica,Arial,sans-serif;line-height:1.4}.offside-module__D5MO1a__header{text-align:center;margin-bottom:1.5rem}.offside-module__D5MO1a__header h1{margin-bottom:.25rem}.offside-module__D5MO1a__content{flex-direction:column;gap:1.5rem;display:flex}.offside-module__D5MO1a__fieldSection{flex-direction:column;gap:1.25rem;display:flex}.offside-module__D5MO1a__fieldFrame{background:#0d5c28;border:24px solid #07351a;border-radius:18px;width:960px;max-width:100%;margin:0 auto 1.25rem;padding:24px;position:relative;box-shadow:0 12px 30px #00000040}.var-box{max-width:960px;margin:0 auto}.offside-module__D5MO1a__field{aspect-ratio:120/80;background:radial-gradient(circle,#ffffff1a,#0000 60%),#118a3c;border-radius:8px;width:100%;min-height:520px;position:relative;overflow:hidden}.offside-module__D5MO1a__fieldMarkings,.offside-module__D5MO1a__fieldOverlay{pointer-events:none;position:absolute;inset:0}.offside-module__D5MO1a__fieldMarkings{z-index:1}.offside-module__D5MO1a__fieldOverlay{z-index:4}.offside-module__D5MO1a__legend,.offside-module__D5MO1a__lawExtract{background:#fff;border-radius:8px;padding:1rem;box-shadow:0 5px 20px #00000014}.offside-module__D5MO1a__legend ul{padding-left:1.25rem;list-style:outside}@media (max-width:980px){.offside-module__D5MO1a__fieldFrame{border-width:16px;padding:16px}.offside-module__D5MO1a__field{min-height:0}}:is(.player,.ball,.pass-handle){color:#fff;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;z-index:2;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-weight:600;display:flex;position:absolute;transform:translate(-50%,-50%)}:is(.player:active,.ball:active,.pass-handle:active){cursor:grabbing}.player.attacker{background:#c62828}.player.defender{background:#1976d2}.player.goalkeeper{background:#0d47a1;border:2px solid #fff}.ball{z-index:3;background:#fff url(/offside/soccer-ball.png) 50%/cover no-repeat;border:2px solid #111;width:24px;height:24px}.pass-handle{color:#333;z-index:2;background:#fff;border:2px dashed #555;width:20px;height:20px}.var-box{color:#fff;z-index:4;background:#111;border-radius:8px;width:100%;padding:1rem;position:static;box-shadow:0 10px 30px #0000004d}.var-title{text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem;font-size:.85rem;font-weight:700}.var-status{font-size:1.25rem}.var-status.offside{color:#ff5252}.var-status.onside{color:#7cfc00}.var-explanation{color:#f1f1f1;min-height:2.6em;margin-top:.5rem;font-size:.85rem;line-height:1.3}@media (max-width:720px){:is(.player,.ball,.pass-handle){width:27px;height:27px}.ball{width:18px;height:18px}.pass-handle{width:15px;height:15px}.var-explanation{min-height:3.9em}}.var-checklist{color:#dcdcdc;margin:.35rem 0 0;padding-left:1.2rem;font-size:.85rem;line-height:1.2}.player.selected{box-shadow:0 0 0 3px #fff,0 0 0 6px #ffeb3be6}.player.offside-position:after{content:"";opacity:.8;pointer-events:none;border:3px solid #ff5252;border-radius:50%;animation:1s ease-in-out infinite offside-module__D5MO1a__offsidePulse;position:absolute;inset:-10px}@keyframes offside-module__D5MO1a__offsidePulse{0%{opacity:.9;transform:scale(.85)}70%{opacity:.2;transform:scale(1.25)}to{opacity:0;transform:scale(1.4)}}
