:root{--bg:#5f7d17;--panel:#ff8c00;--btn:#e8e8e8;--btn2:#d5d5d5;--on:#fffb8f;--off:#888888;--text:#000;--safe:#b87333;--blue:#2b45ff;--pink:#d67aa7;--black:#101010;--red:#e10000;--yellow:#ffea00;--green:#31ff31;--brown:#6b3f1d}*{box-sizing:border-box;-webkit-tap-highlight-color:rgba(0,0,0,0)}html,body{height:100%;margin:0;background:#000;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;overscroll-behavior:none}body{touch-action:manipulation;overflow:hidden}button,a,select,input,label{touch-action:manipulation}#app{height:100%;background:var(--bg);display:flex;flex-direction:column}.topnav,.controls,.bottomTabs{flex:0 0 auto}.topnav{display:flex;justify-content:space-between;padding:10px;padding-top:calc(10px + env(safe-area-inset-top))}.topnav button{font-size:22px;padding:10px 18px;border-radius:10px;border:1px solid rgba(0,0,0,.35);background:linear-gradient(#9ac35f,#5e8b1a);color:#fff;font-weight:700}.main{flex:1;display:flex;flex-direction:column;min-height:0;padding:8px 10px 0;gap:8px}.headerRow{display:grid;grid-template-columns:1fr 120px 1fr;gap:10px;align-items:flex-start}.playerBox{position:relative;padding:8px 10px 10px;min-height:0}.playerBox[style*="text-align:right"] .breakBalls{justify-content:flex-end}.playerName{font-size:34px;color:#000;background:#ff8c00f2;padding:6px 10px;border-radius:8px;font-weight:800}.playerName.turn{outline:5px solid #fff;outline-offset:2px}.scoreBig{font-size:105px;font-weight:900;color:#000;line-height:1;margin-top:6px}.scoreBig.needsSnookers{display:inline-block;background:#fff;border-radius:14px;padding:4px 12px}.breakLine{font-size:38px;margin-top:6px;color:#000}.breakBalls{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap;width:100%;justify-content:center}.ballDot{width:16px;height:16px;border-radius:99px;border:1px solid rgba(0,0,0,.55)}.centerBox{text-align:center;font-size:44px;font-weight:900;color:#000}.subCenter{font-size:18px;font-weight:700;margin-top:6px}.infoRow{display:flex;justify-content:space-between;gap:10px;padding:8px 10px;border-radius:10px;background:#ff8c00f2;color:#000;font-weight:900;font-size:20px}.infoLeft{opacity:.95}.infoRight{opacity:.95;text-align:right}.logBox,.list{min-height:0}.logBox{background:var(--panel);padding:10px;border-radius:10px;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;font-size:22px;line-height:1.25}.logLine{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logLine[data-seat=left]{color:#fff}.logLine[data-seat=right]{color:#000}.controls{display:flex;flex-direction:column;gap:10px;padding:8px 10px 10px}button.on{background:#fff!important;color:#000!important}.toggleRow{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:100%}.toggleRow button{width:100%;font-size:22px;font-weight:900;padding:20px 0;border-radius:12px;border:1px solid rgba(0,0,0,.35);background:var(--off);color:#fff}.toggleRow button.on{background:var(--on)!important;color:#000!important}.togglesWide{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:100%;align-items:stretch}.togglesWide button{width:100%;padding:20px 0;font-size:22px;font-weight:900;border-radius:12px}.actionRow{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:100%}.actionRow button{width:100%;font-size:26px;font-weight:900;padding:20px 0;border-radius:12px;border:1px solid rgba(0,0,0,.35);background:var(--btn);color:#000}.actionRow button.primary{background:var(--btn2)}.actionRow button:disabled{opacity:.35}.ballGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.ballGrid button{padding:23px 0;border-radius:14px;border:2px solid rgba(255,255,255,.25);font-size:22px;font-weight:900;color:#fff!important;text-shadow:none}.ballGrid button:disabled{opacity:.25}.b_red{background:var(--red)}.b_yellow{background:var(--yellow)}.b_green{background:var(--green)}.b_brown{background:var(--brown)}.b_blue{background:var(--blue)}.b_pink{background:var(--pink)}.b_black{background:var(--black)}.ballGrid button.b_red,.ballGrid button.b_blue,.ballGrid button.b_black{text-shadow:0 1px 2px rgba(0,0,0,.85)}.bottomTabs{display:grid;grid-template-columns:repeat(3,1fr);border-top:2px solid rgba(0,0,0,.25);background:#0003;padding-bottom:calc(env(safe-area-inset-bottom) + 3px)}.bottomTabs button{padding:10px 0;font-size:20px;font-weight:900;background:transparent;border:none;color:#ffffffa6}.bottomTabs button.on{color:#2ea3ff}.toast{position:fixed;left:50%;bottom:calc(90px + env(safe-area-inset-bottom));transform:translate(-50%);background:#000000d9;color:#fff;padding:10px 14px;border-radius:10px;font-size:16px;max-width:90%;z-index:9999}.modalBack{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:18px;z-index:9998}.modal{width:min(560px,96vw);background:#f5f5f5f5;border-radius:16px;padding:16px;color:#000}.modal h2{margin:0 0 10px;font-size:28px}.modal .row{display:flex;gap:10px;margin:10px 0;align-items:center;flex-wrap:wrap}.modal label{font-weight:800}.modal button{font-size:22px;padding:12px 14px;border-radius:12px;border:1px solid rgba(0,0,0,.35);background:#e8e8e8;font-weight:900;color:#000}.modal button.danger{color:#d00000}.small{font-size:16px;opacity:.8}.list{background:#ff8c00f2;border-radius:10px;padding:10px;overflow:auto;flex:1}.listItem{display:flex;justify-content:space-between;align-items:center;padding:10px;background:#ffffff26;border-radius:10px;margin-bottom:10px;color:#fff}.listItem .title{font-weight:900;font-size:22px}.listItem .sub{font-size:14px;opacity:.9}.listItem button{font-size:18px;padding:10px 12px;border-radius:10px;border:none;font-weight:900}.screen{flex:1;display:flex;flex-direction:column;min-height:0}.onLine{font-size:16px;font-weight:800;margin-top:6px;color:#000}@media(orientation:portrait){.scoreBig{font-size:clamp(108px,12vh,138px)}.breakLine{font-size:clamp(34px,4.6vh,52px)}.centerBox{font-size:clamp(38px,4.8vh,52px)}.subCenter{font-size:clamp(16px,2.2vh,22px)}.ballDot{width:clamp(16px,2vh,22px);height:clamp(16px,2vh,22px)}.toggleRow button,.togglesWide button{padding:clamp(20px,2.8vh,28px) 0;font-size:clamp(20px,2.2vh,26px)}.actionRow button{padding:clamp(20px,2.8vh,28px) 0;font-size:clamp(22px,2.6vh,30px)}.ballGrid button{padding:clamp(24px,3.2vh,34px) 0;font-size:clamp(22px,2.4vh,28px)}.logBox{font-size:clamp(18px,2vh,22px);line-height:1.15}.bottomTabs button{padding:clamp(18px,2.6vh,28px) 0;font-size:clamp(20px,2.2vh,26px)}}#app,.screen{min-height:0}.screen{height:100%}.main{min-height:0;overflow:hidden}.logBox{flex:1 1 auto;min-height:0;overflow-y:auto}.headerRow>*{min-width:0}.playerName{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:430px){.headerRow{grid-template-columns:1fr 92px 1fr;gap:6px}.playerBox{padding:6px 8px 8px}.playerName{font-size:22px;padding:5px 8px;border-radius:8px}.scoreBig{font-size:clamp(64px,17vw,110px);margin-top:4px}.scoreBig.needsSnookers{padding:3px 10px;border-radius:12px}.centerBox{font-size:clamp(22px,6vw,34px)}.subCenter{font-size:clamp(14px,4vw,18px)}.subCenter span{font-size:clamp(28px,10vw,44px)!important}.breakBalls{gap:4px}.ballDot{width:14px;height:14px}}@media(max-width:430px){.main{padding:6px 8px 0;gap:6px}.infoRow{padding:6px 8px;font-size:16px}.controls{gap:6px;padding:6px 8px}.toggleRow button,.togglesWide button{padding:12px 0;font-size:18px;border-radius:10px}.actionRow button{padding:12px 0;font-size:20px;border-radius:10px}.ballGrid button{padding:16px 0;font-size:18px;border-radius:12px}.bottomTabs{padding-bottom:3px}.bottomTabs button{padding:10px 0;font-size:18px}.modal button{font-size:18px;padding:10px 12px;border-radius:10px}.logBox{font-size:18px;line-height:1.15;padding:8px;flex:1 1 auto;min-height:0}}
