body{font-family:system-ui,Arial,sans-serif;margin:0;background:#ede2d2;color:#2b241c;-webkit-font-smoothing:antialiased}:root{--cell-h:20px;--cell-gap:.55rem}.no-vert-scroll html,.no-vert-scroll body{overflow:hidden}.app{max-width:100%;margin:0;padding:.75rem 0 0;box-sizing:border-box;min-height:100dvh;position:relative;overflow-x:hidden;height:100dvh;display:flex;flex-direction:column}form{background:#fff6eb;padding:.6rem .7rem 1rem;border-radius:16px;box-shadow:0 4px 20px -6px #0003,0 0 0 1px #d4c1a8 inset}h1{font-size:1.25rem;margin:.25rem .3rem .6rem;letter-spacing:.5px;font-weight:650;text-align:center}.reset-btn{position:absolute;top:.4rem;right:.65rem;background:#b84b38;color:#fff;border:2px solid #8d3525;font-weight:650;font-size:.8rem;letter-spacing:.5px;padding:.45rem .75rem .4rem;border-radius:12px;cursor:pointer;box-shadow:0 2px 6px #00000040,0 0 0 2px #ffffff80 inset;transition:background .15s,transform .15s,box-shadow .15s}.reset-btn:hover,.reset-btn:focus{background:#d25541;outline:none}.reset-btn:active{transform:translateY(2px);box-shadow:0 1px 3px #00000059 inset}fieldset{border:0px solid #cbb89d;margin:0 0 .85rem;border-radius:14px;padding:.55rem .6rem .65rem}legend{padding:0 .5rem;font-weight:600}.row{display:flex;justify-content:space-between;align-items:center;min-height:var(--cell-h);height:var(--cell-h)}.row label{flex:1;display:flex;align-items:center;justify-content:flex-start;gap:var(--cell-gap);min-height:var(--cell-h);height:var(--cell-h)}input[type=number]{width:100%;padding:.15rem .5rem .13rem;font-size:.9rem;height:20px;line-height:1;border-radius:8px;border:2px solid #c7ac86;background:#fff;font-weight:600;text-align:right;box-shadow:0 2px 3px -1px #0000002e inset}input[type=number]:focus{outline:2px solid #6a9bff;border-color:#6a9bff;background:#fffef9}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.ios-device input[type=number]{font-size:16px!important;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent}.ios-device input[type=text]{font-size:16px!important;-webkit-tap-highlight-color:transparent}.ios-device .row label{padding:4px 0;touch-action:manipulation}.ios-device button{-webkit-tap-highlight-color:transparent;touch-action:manipulation}.ios-device .players-carousel{-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;touch-action:pan-x}output{min-width:2ch;display:inline-block;text-align:center;font-variant-numeric:tabular-nums}.columns{display:flex;gap:.9rem;align-items:stretch;flex-wrap:nowrap;margin-top:.3rem;height:100%}.column{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:flex-start;height:100%;gap:.6rem}.column .row{flex:0 0 auto;height:var(--cell-h);margin-top:9px}.column .row label{width:100%;height:100%}.total-line,.grand-total{display:none}.sheet-style fieldset{background:#ead6bd;border-color:#b99c74}.sheet-style .column{background:#d9ba93;padding:.42rem .48rem .55rem;border-radius:14px;position:relative}.sheet-style .column:before{content:"";position:absolute;top:-10px;left:50%;transform:translate(-50%);width:66%;height:16px;background:#c7a780;border-radius:8px;box-shadow:0 2px 4px #0000002e inset}.swatch{width:var(--cell-h);height:var(--cell-h);border-radius:10px;flex:0 0 var(--cell-h);box-shadow:0 2px 4px #00000040 inset,0 0 0 2px #00000026;position:relative}.biome-green{background:#4caf50}.biome-grey{background:#b0b0b0}.biome-yellow{background:#ffcf33}.biome-red{background:#e53935}.biome-blue{background:#2196f3}.animal-slot{background:linear-gradient(135deg,#fff,#e3e3e3)}.totals-bar{background:#f7dcb8;margin:0;position:fixed;left:.45rem;right:.45rem;bottom:0;padding:.6rem .9rem calc(.85rem + env(safe-area-inset-bottom));border:2px solid #c6aa87;border-bottom:0;border-radius:16px 16px 0 0;box-shadow:0 -2px 12px -4px #00000047;z-index:20;display:flex;flex-direction:column;align-items:center;gap:.55rem}.totals-expression{display:flex;align-items:center;gap:.65rem;justify-content:center;font-size:1.05rem}.mini-block{min-width:72px;min-height:54px;background:#fffdf9;border:2px solid #c9a97f;border-radius:14px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.35rem;box-shadow:0 2px 4px #00000026}.mini-block.grand{background:#ffd889;border-color:#f0b13d;font-size:1.55rem}.op{font-weight:700;font-size:1.5rem;color:#6b5235;line-height:1}.leaderboard{width:100%;display:flex;flex-wrap:nowrap;justify-content:flex-start;gap:.55rem .6rem;padding:.45rem .25rem 0;margin-top:.25rem;border-top:1px dashed #c7a97f;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;touch-action:pan-x}.leaderboard::-webkit-scrollbar{display:none}.leaderboard .lb-item{background:#ffffffeb;border:2px solid #c7a97f;border-radius:14px;padding:.4rem .75rem .45rem;font-size:.75rem;display:flex;align-items:center;gap:.45rem;box-shadow:0 2px 4px #0000002e;font-weight:600;letter-spacing:.4px;line-height:1;min-width:110px;justify-content:space-between;flex:0 0 auto}.leaderboard .lb-item.active{background:#ffe2ab;border-color:#f0b13d;box-shadow:0 2px 6px #00000038}.leaderboard .lb-item.leader{font-weight:800;transform:translateY(-2px)}.leaderboard .lb-item.leader .lb-score{text-decoration:underline;font-weight:800;color:#2e7d32;background:#4caf501a;padding:2px 6px;border-radius:6px}.leaderboard .lb-name{flex:1 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.leaderboard .lb-score{font-variant-numeric:tabular-nums;font-weight:700;color:#6b5235;font-size:.85rem}@media (max-width:480px){.leaderboard .lb-item{min-width:100px}}.players-carousel{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;position:relative;width:100%;touch-action:pan-x;overscroll-behavior-x:contain;overscroll-behavior-y:none;scrollbar-width:none}.players-carousel::-webkit-scrollbar{display:none}.swipe-indicator{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:28px;height:48px;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:300;color:#444;opacity:.35;pointer-events:none;-webkit-user-select:none;user-select:none;font-family:system-ui,sans-serif;text-shadow:0 0 4px rgba(255,255,255,.9)}.swipe-indicator.left{left:2px}.swipe-indicator.right{right:2px}.swipe-indicator.hidden{display:none}.players-carousel:active{cursor:grabbing}.player-sheet .columns{min-height:0}@media (min-width:800px){.player-sheet{flex:0 0 50%}}.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.player-name-wrapper{position:relative;width:100%;display:flex;margin:0 0 .6rem}.top-name{background:#f1e0c8;padding:.35rem .45rem .45rem;border:1px solid #cbb89d;border-radius:14px;box-shadow:0 2px 6px -2px #0000002e inset}.player-name{width:100%;font-family:Trebuchet MS,Segoe UI,system-ui,sans-serif;font-size:1.55rem;line-height:1.15;padding:.5rem .7rem .45rem;border:2px solid #c6a780;border-radius:12px;background:linear-gradient(145deg,#fffefb,#f3e4d2);font-weight:650;letter-spacing:.5px;box-shadow:0 2px 4px #0000001f,0 0 0 2px #fff9 inset;box-sizing:border-box}.ios-device .player-name{font-size:16px!important;-webkit-tap-highlight-color:transparent}.player-name-wrapper{position:relative}.name-clear{position:absolute;right:.35rem;top:50%;transform:translateY(-50%);background:#8a6a46;border:0;color:#fff;width:28px;height:28px;border-radius:50%;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 4px #00000059;transition:background .15s,transform .15s;font-weight:700}.name-clear:hover,.name-clear:focus{background:#a77f55;outline:none}.name-clear:active{transform:translateY(-50%) scale(.9)}.player-name:not(:placeholder-shown)+.name-clear,.player-name:focus+.name-clear{opacity:1}.name-clear{opacity:.85}.player-name:focus{outline:3px solid #7da7ff;outline-offset:2px}.player-name::placeholder{color:#b79d7d;opacity:.55;font-weight:400}@media (max-width:480px){.player-name{font-size:1.35rem;padding:.45rem .6rem .4rem}}@media (min-width: 640px){.app{padding:1rem 1rem 7rem}h1{font-size:1.35rem}.columns{gap:1.2rem}input[type=number]{width:100%}.swatch{width:40px;height:40px}.mini-block{min-width:80px;min-height:60px;font-size:1.45rem}.mini-block.grand{font-size:1.7rem}}@media (max-width: 400px){.player-sheet{padding:0 .45rem}.columns{gap:.5rem}.sheet-style .column{padding:.34rem .38rem .42rem}.sheet-style .column:before{width:60%;height:14px;top:-8px}:root{--cell-h:20px;--cell-gap:.5rem}.swatch{border-radius:6px}input[type=number]{width:56px;font-size:.85rem;padding:.12rem .45rem .1rem;height:20px}.player-name{font-size:1.25rem;padding:.45rem .6rem .4rem}.mini-block{min-width:62px;min-height:48px;font-size:1.15rem}.mini-block.grand{font-size:1.3rem}.leaderboard{gap:.4rem}.leaderboard .lb-item{padding:.35rem .55rem .4rem;font-size:.65rem;min-width:auto;flex:1 1 0}.leaderboard .lb-name{max-width:60px}}@media (max-width: 340px){:root{--cell-h:20px}input[type=number]{width:50px;font-size:.8rem;height:20px}.columns{gap:.42rem}.player-name{font-size:1.15rem}.leaderboard .lb-name{max-width:48px}}@media (max-height: 780px){:root{--totals-h: 210px}.mini-block{min-height:50px;font-size:1.25rem}.mini-block.grand{font-size:1.4rem}.totals-bar{padding:.55rem .75rem calc(.75rem + env(safe-area-inset-bottom))}.player-name{font-size:1.45rem;padding:.48rem .65rem .42rem}.players-carousel{padding-bottom:var(--totals-h)}}@media (max-height: 720px){:root{--totals-h: 190px}.player-name{font-size:1.35rem}.swatch{width:24px;height:24px}input[type=number]{padding:.12rem .4rem;height:20px;font-size:.9rem;width:100%}.mini-block{min-height:46px;min-width:66px;font-size:1.18rem}.mini-block.grand{font-size:1.3rem}.totals-expression{gap:.5rem}.players-carousel{padding-bottom:var(--totals-h)}}@media (max-height: 660px){:root{--totals-h: 175px}.player-name{font-size:1.28rem;padding:.42rem .6rem .38rem}.swatch{width:22px;height:22px}input[type=number]{height:20px;width:100%;font-size:.85rem}.mini-block{min-height:42px;min-width:60px;font-size:1.05rem}.mini-block.grand{font-size:1.2rem}.leaderboard .lb-item{padding:.32rem .55rem .35rem;font-size:.62rem}.totals-bar{padding:.5rem .65rem calc(.65rem + env(safe-area-inset-bottom))}.players-carousel{padding-bottom:var(--totals-h)}}@media (max-height: 620px){:root{--totals-h: 165px}h1{margin:.15rem .3rem .4rem;font-size:1.1rem}.player-name{font-size:1.22rem}.swatch{width:20px;height:20px}input[type=number]{height:20px;width:52px;padding:.12rem .38rem}.mini-block{min-height:38px;min-width:56px;font-size:.95rem}.mini-block.grand{font-size:1.08rem}.totals-expression{gap:.4rem}.players-carousel{padding-bottom:var(--totals-h)}}@media (max-height: 580px){:root{--totals-h: 155px}.player-name{font-size:1.15rem;padding:.38rem .55rem .34rem}.swatch{width:20px;height:20px}input[type=number]{height:20px;width:50px;font-size:.8rem}.mini-block{min-height:36px;min-width:52px;font-size:.9rem}.mini-block.grand{font-size:1rem}.leaderboard{gap:.35rem}.leaderboard .lb-item{padding:.28rem .45rem .3rem}.players-carousel{padding-bottom:var(--totals-h)}}:root{--totals-h: 200px}html,body{height:100%;overflow:hidden}form{flex:1;display:flex;flex-direction:column;overflow:hidden}.players-carousel{flex:1;padding-bottom:var(--totals-h);overflow:hidden}.player-sheet{flex:0 0 100%;width:100%;scroll-snap-align:start;box-sizing:border-box;padding:0 .75rem;min-height:0;height:100%;display:flex;flex-direction:column}
