:root{--turf: #62ad27;--turf-light: #75c728;--turf-dark: #389804;--sky: #62c2fb;--sky-light: #93daf9;--cloud: #ecf0eb;--ink: #243018;--panel: #ffffff;--p-red: #e8453c;--p-blue: #2e80e8;--p-yellow: #f5c518;--p-mint: #5bd6a6;--p-purple: #9b5be8;--p-orange: #f08a24;--font-display: "Fredoka", system-ui, sans-serif;--font-body: "Nunito", system-ui, sans-serif}*{box-sizing:border-box;margin:0;padding:0;-webkit-user-select:none;user-select:none}html,body,#root{width:100%;height:100%;overflow:hidden;font-family:var(--font-body);color:var(--ink);background:var(--sky)}canvas{display:block;touch-action:none}.btn{font-family:var(--font-display);font-weight:600;font-size:1.15rem;border:none;border-radius:16px;padding:16px 28px;cursor:pointer;color:#fff;background:var(--turf);box-shadow:0 5px 0 0 var(--turf-dark),0 8px 16px #0000002e;transition:transform .06s ease,box-shadow .06s ease,filter .15s ease}.btn:hover{filter:brightness(1.05)}.btn:active{transform:translateY(4px);box-shadow:0 1px 0 0 var(--turf-dark),0 3px 8px #0000002e}.btn--secondary{background:#fff;color:var(--ink);box-shadow:0 5px #c9cfc4,0 8px 16px #00000024}.btn--secondary:active{box-shadow:0 1px #c9cfc4,0 3px 8px #00000024}.btn:disabled{opacity:.5;cursor:not-allowed}.menu{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;background:linear-gradient(180deg,var(--sky-light) 0%,var(--sky) 55%,var(--turf-light) 130%);text-align:center;padding:24px}.menu h1{font-family:var(--font-display);font-weight:700;font-size:clamp(2.4rem,7vw,4.5rem);color:#fff;text-shadow:0 4px 0 rgba(0,0,0,.12),0 2px 10px rgba(0,0,0,.18);letter-spacing:.5px}.menu h1 .accent{color:var(--p-yellow)}.menu .tagline{font-weight:700;color:var(--ink);opacity:.7;margin-top:-8px}.ball-preview{width:120px;height:120px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#fff,#e6e6e6 55%,#cfcfcf);box-shadow:inset -10px -12px 24px #0000002e,0 10px 24px #0003;margin:6px 0;transition:background .15s ease}.swatches{display:flex;gap:10px}.swatch{width:34px;height:34px;border-radius:50%;border:3px solid rgba(255,255,255,.8);cursor:pointer;box-shadow:0 3px 8px #0003;transition:transform .08s ease}.swatch:hover{transform:scale(1.1)}.swatch.on{border-color:var(--ink);transform:scale(1.15)}.name-input{font-family:var(--font-body);font-weight:700;font-size:1rem;text-align:center;border:none;border-radius:12px;padding:12px 18px;width:240px;box-shadow:inset 0 2px 6px #0000001f}.menu-actions{display:flex;flex-direction:column;gap:12px;width:min(320px,80vw)}.hud{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;font-family:var(--font-display)}.pill{position:absolute;background:#ffffffeb;color:var(--ink);font-weight:600;border-radius:999px;padding:8px 16px;box-shadow:0 3px 10px #00000029;display:flex;align-items:center;gap:8px}.hud .hole{top:18px;left:18px;font-size:1.05rem}.hud .strokes{top:18px;left:50%;transform:translate(-50%)}.hud .menu-btn{top:18px;right:18px;pointer-events:auto;cursor:pointer;border:none;font-family:var(--font-display)}.hud .hint{bottom:70px;left:50%;transform:translate(-50%);background:#141e128c;color:#fff;font-family:var(--font-body);font-weight:700;font-size:.9rem;text-align:center}.powerbox{position:absolute;left:24px;bottom:26px;width:440px;max-width:52vw;pointer-events:none}.powerbox-label{font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:.1em;text-transform:uppercase;color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.55);margin:0 0 8px 4px}.powerbar{position:relative;width:100%;height:40px;background:#141e1257;border:2px solid rgba(255,255,255,.6);border-radius:18px;overflow:hidden;box-shadow:0 4px 14px #00000052}.powerbar-fill{height:100%;width:0%;border-radius:16px 0 0 16px;transition:width .04s linear}.powertick{position:absolute;top:6px;bottom:6px;width:2px;background:#ffffffb3;transform:translate(-1px);pointer-events:none}.end{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;background:linear-gradient(180deg,#141e1266,#141e12b3);color:#fff;text-align:center;padding:24px}.end h2{font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,6vw,3.4rem)}.scorecard{background:#fffffff2;color:var(--ink);border-radius:16px;padding:16px 22px;min-width:260px;font-weight:700}.scorecard .row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid rgba(0,0,0,.08)}.scorecard .row.total{border-bottom:none;font-family:var(--font-display);font-size:1.2rem;padding-top:10px}.editor{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;grid-template-rows:auto 1fr auto;background:linear-gradient(180deg,var(--sky-light),var(--sky))}.ed-top{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;background:#ffffffe6;box-shadow:0 2px 12px #0000001f;z-index:2}.ed-title{font-family:var(--font-display);font-weight:700;font-size:1.4rem;color:var(--ink)}.ed-actions{display:flex;gap:8px}.ed-btn{font-family:var(--font-display);font-weight:600;border:none;border-radius:12px;padding:9px 14px;cursor:pointer;background:#fff;color:var(--ink);box-shadow:0 3px #c9cfc4}.ed-btn:active{transform:translateY(3px);box-shadow:0 0 #c9cfc4}.ed-btn--play{background:var(--turf);color:#fff;box-shadow:0 3px 0 0 var(--turf-dark)}.ed-btn:disabled{opacity:.45;cursor:not-allowed}.ed-main{display:grid;grid-template-columns:340px 1fr;min-height:0}.ed-side{overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px;background:#ffffff8c}.ed-section-title{font-family:var(--font-display);font-weight:700;font-size:.95rem;color:var(--ink);opacity:.85;margin-top:4px}.ed-palette{display:grid;grid-template-columns:1fr 1fr;gap:8px}.ed-pal-btn{font-family:var(--font-body);font-weight:700;border:none;border-radius:10px;padding:10px;cursor:pointer;background:var(--turf-light);color:#fff;box-shadow:0 2px 0 0 var(--turf-dark)}.ed-pal-btn:active{transform:translateY(2px);box-shadow:0 0 0 0 var(--turf-dark)}.ed-mods{display:flex;flex-direction:column;gap:6px}.ed-mod-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.ed-mod-label{width:58px;font-weight:700;font-size:.8rem;opacity:.7}.ed-chip-btn{font-family:var(--font-body);font-weight:700;font-size:.8rem;border:2px solid rgba(0,0,0,.12);border-radius:999px;padding:5px 11px;cursor:pointer;background:#fff;color:var(--ink)}.ed-chip-btn.on{background:var(--p-blue);color:#fff;border-color:var(--p-blue)}.ed-issues{display:flex;flex-direction:column;gap:5px}.ed-issue{font-size:.78rem;padding:6px 9px;border-radius:8px;background:#fff;line-height:1.3}.ed-issue.ok{background:#e7f6e1}.ed-issue.warn{background:#fff4d6}.ed-issue.error{background:#ffe0dd}.ed-preview{position:relative;min-height:0}.ed-preview-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--ink);font-weight:700;padding:24px;text-align:center}.ed-seq{display:flex;gap:8px;padding:12px;overflow-x:auto;background:#ffffffe6;box-shadow:0 -2px 12px #0000001a}.ed-chip{flex:0 0 auto;min-width:128px;border-radius:12px;padding:8px 10px;background:#fff;border:3px solid transparent;cursor:pointer;box-shadow:0 2px 6px #0000001f}.ed-chip.sel{border-color:var(--p-blue)}.ed-chip.warn{background:#fff4d6}.ed-chip.err{background:#ffe0dd}.ed-chip-name{font-family:var(--font-display);font-weight:700;font-size:.9rem}.ed-chip-tags{font-size:.72rem;opacity:.7;margin-top:2px}.ed-chip-ctrl{display:flex;gap:4px;margin-top:6px}.ed-chip-ctrl button{border:none;border-radius:6px;width:26px;height:24px;cursor:pointer;background:#eef0ec;font-weight:700}.ed-note{position:absolute;bottom:96px;left:50%;transform:translate(-50%);background:#141e12e0;color:#fff;padding:10px 16px;border-radius:10px;font-weight:700;cursor:pointer;z-index:5}.ed-addons{display:flex;flex-direction:column;gap:5px}.ed-addon{font-size:.8rem;font-weight:700;padding:6px 9px;border-radius:8px;background:#fff;border:2px solid transparent;cursor:pointer}.ed-addon.sel{border-color:var(--p-yellow);background:#fff8df}.ed-addon-ctrl{display:flex;gap:4px;margin-top:5px;flex-wrap:wrap}.ed-addon-ctrl button{border:none;border-radius:6px;width:26px;height:24px;cursor:pointer;background:#eef0ec;font-weight:700}
