:root{--cell:min(44px, calc((100dvh - 40px) / 11.5), calc((100dvw - 270px) / 15))}@media (orientation:portrait){:root{--cell:min(44px, calc((100dvw - 40px) / 11.5), calc((100dvh - 270px) / 15))}}:root{--gap:2px;--bg:#f0e8d8;--surface:#e4dccb;--surface-2:#d8d0be;--surface-3:#ccc4b2;--border:#c0b8a6;--text:#c06030;--text-dim:#b07050;--text-bright:#a04020;--accent:#c06090;--green:#90d8ac;--orange:#ffb890;--yellow:#ffea90;--blue:#90c8e8;--pink:#f098b8;--green-dark:#3a6848;--orange-dark:#7a4c28;--yellow-dark:#706018;--blue-dark:#305870;--pink-dark:#703048}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);width:100%;height:100dvh;color:var(--text);touch-action:manipulation;-webkit-user-select:none;user-select:none;font-family:system-ui,-apple-system,sans-serif;position:fixed;inset:0;overflow:hidden}#root{width:100%;height:100%;overflow:hidden}@media (orientation:portrait){#root{transform-origin:0 0;width:100dvh;height:100dvw;position:absolute;top:0;left:100dvw;transform:rotate(90deg)}.cell,.col-label,.row-letter,.row-score-left,.col-score,.heart-track-cell,.die,.counter-cell,.speed-count,.track-controls .btn,.sp-pip,.sp-atom,.sp-num{transform:rotate(-90deg)}.cell.selected{transform:rotate(-90deg)scale(1.08)}.score-panel{writing-mode:vertical-rl;transform:rotate(180deg)}.score-panel *{writing-mode:horizontal-tb}.special-badge,.waiting-badge{transform:rotate(-90deg)}.menu-screen,.lobby-screen{width:100%;height:100%}.game-over{transform-origin:0 0;width:100dvh;height:100dvw;position:fixed;top:0;left:100dvw;transform:rotate(-90deg)}}.game{grid-template:"board score"1fr/1fr auto;gap:4px;width:100%;height:100%;padding:4px;display:grid;overflow:hidden}.board-area{grid-area:board;justify-content:center;align-items:center;display:flex;overflow:hidden}.board-inner{align-items:stretch;gap:4px;display:flex}.row-scores-left,.row-labels-right{gap:var(--gap);flex-direction:column;flex-shrink:0;display:flex}.row-scores-spacer{height:calc(var(--cell) + var(--gap))}.row-score-left{width:var(--cell);height:var(--cell);font-size:calc(var(--cell) * .35);color:var(--text-dim);flex-direction:column;justify-content:center;align-items:center;font-weight:600;display:flex}.row-score-left .row-pts{color:var(--text);font-weight:800;font-size:calc(var(--cell) * .4)}.row-score-left .row-bonus-icon{font-size:calc(var(--cell) * .35)}.row-score-left.completed,.row-score-left.completed .row-pts{color:var(--green)}.row-score-left.claimed .row-bonus-icon{opacity:.3;text-decoration:line-through}.row-letter{width:var(--cell);height:var(--cell);font-size:calc(var(--cell) * .45);color:var(--text-dim);justify-content:center;align-items:center;font-weight:700;display:flex}.row-letter.completed{color:var(--green)}.grid-wrapper{flex-direction:column;align-items:center;gap:1px;display:flex}.col-labels{grid-template-columns:repeat(15, var(--cell));gap:var(--gap);display:grid}.col-label{width:var(--cell);height:var(--cell);font-size:calc(var(--cell) * .42);color:var(--text-dim);justify-content:center;align-items:center;font-weight:600;display:flex}.col-label:nth-child(8){color:var(--text-bright)}.grid{grid-template-columns:repeat(15, var(--cell));grid-template-rows:repeat(7, var(--cell));gap:var(--gap);display:grid}.cell{cursor:default;font-size:calc(var(--cell) * .35);-webkit-tap-highlight-color:transparent;border:none;border-radius:4px;justify-content:center;align-items:center;font-weight:700;transition:transform .1s,box-shadow .1s;display:flex;position:relative}.grid>.cell:nth-child(15n+8){outline-offset:-1px;outline:2px solid #ffffff40}.game.placing .grid>.cell:nth-child(15n+8){outline:none}.cell[data-color=green]{background:var(--green);color:var(--green-dark)}.cell[data-color=orange]{background:var(--orange);color:var(--orange-dark)}.cell[data-color=yellow]{background:var(--yellow);color:var(--yellow-dark)}.cell[data-color=blue]{background:var(--blue);color:var(--blue-dark)}.cell[data-color=pink]{background:var(--pink);color:var(--pink-dark)}.cell{--opp-sz:calc(var(--cell) * .22)}.opp-corner{z-index:1;pointer-events:none;width:0;height:0;position:absolute}.cell.crossed:after{content:"✕";font-size:calc(var(--cell) * .65);color:#00000059;text-shadow:0 0 2px #fff3;font-weight:900;position:absolute}.game.placing:not(.masked) .cell:not(.valid):not(.selected):not(.reachable){opacity:.2;transition:opacity .2s}.game.placing:not(.masked) .cell.reachable{opacity:.55;transition:opacity .2s}.game.masked .cell.valid{overflow:hidden;color:#0000!important;font-size:0!important}.game.masked .cell.valid:before{content:"";pointer-events:none;z-index:2;background:#fff;border-radius:4px;position:absolute;inset:0}.cell.valid{cursor:pointer}.cell.valid:active{transform:scale(.9)}.cell.selected{cursor:pointer;box-shadow:0 0 0 3px var(--text-bright), 0 0 14px #fff9;z-index:2;transform:scale(1.08)}.col-scores{grid-template-columns:repeat(15, var(--cell));gap:var(--gap);display:grid}.col-score{width:var(--cell);height:var(--cell);font-size:calc(var(--cell) * .35);color:var(--text-dim);flex-direction:column;justify-content:center;align-items:center;line-height:1.2;display:flex}.col-score .first{color:var(--text);font-weight:700}.col-score.completed .first{color:var(--green)}.heart-track{grid-template-columns:repeat(15, var(--cell));gap:var(--gap);display:grid}.heart-track-cell{width:var(--cell);height:var(--cell);font-size:calc(var(--cell) * .45);color:var(--pink);opacity:.35;justify-content:center;align-items:center;display:flex}.heart-track-cell.earned{opacity:1;font-weight:700}.track-controls,.track-info,.track-status{grid-template-columns:repeat(15, var(--cell));gap:var(--gap);perspective:400px;align-items:center;display:grid}.grid-spacer{display:block}.track-controls .btn,.track-info .btn{font-size:calc(var(--cell) * .38);height:var(--cell);width:var(--cell);border-radius:4px;padding:0}.btn-wide{grid-column:span 2;width:auto!important}.track-controls .waiting-badge{grid-column:1/-1}.counter-cell{width:var(--cell);height:var(--cell);font-size:calc(var(--cell) * .35);color:var(--text);flex-direction:column;justify-content:center;align-items:center;font-weight:700;line-height:1;display:flex}.counter-frac{font-size:calc(var(--cell) * .28);color:var(--text-dim);font-weight:600}.track-status{text-align:center;width:100%}.track-status .phase-hint{font-size:calc(var(--cell) * .35);color:var(--text-dim);white-space:nowrap}.score-panel{gap:calc(var(--cell) * .15);padding:calc(var(--cell) * .2);flex-direction:column;grid-area:score;justify-content:center;display:flex}.sp-turn{font-size:calc(var(--cell) * .4);color:var(--text);text-align:center;font-weight:700}.sp-color-grid{grid-template-columns:repeat(5, var(--cell));gap:var(--gap);display:grid}.sp-pip{width:var(--cell);height:var(--cell);font-size:calc(var(--cell) * .4);color:var(--text-bright);opacity:.5;border-radius:4px;justify-content:center;align-items:center;font-weight:800;display:flex}.sp-pip.done{opacity:1}.sp-pip.dim{opacity:.3;font-size:calc(var(--cell) * .35)}.sp-scores{grid-template-columns:var(--cell) var(--cell) var(--cell) var(--cell);gap:var(--gap);justify-content:center;display:grid}.sp-atom{height:calc(var(--cell) * .7);font-size:calc(var(--cell) * .35);color:var(--text-dim);justify-content:center;align-items:center;font-weight:600;display:flex}.sp-num{height:calc(var(--cell) * .7);font-size:calc(var(--cell) * .4);color:var(--text);font-variant-numeric:tabular-nums;justify-content:center;align-items:center;font-weight:800;display:flex}.sp-atom.penalty,.sp-num.penalty{color:var(--pink)}.sp-total{font-size:calc(var(--cell) * .45);color:var(--text-bright);border-top:2px dashed var(--surface-2);padding-top:calc(var(--cell) * .1);justify-content:space-between;align-items:center;font-weight:800;display:flex}.sp-total span:last-child{color:var(--accent);font-size:calc(var(--cell) * .5)}.die{width:var(--cell);height:var(--cell);font-size:calc(var(--cell) * .4);cursor:pointer;-webkit-tap-highlight-color:transparent;border:2px solid #0000;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;font-weight:800;transition:transform .15s,border-color .15s,box-shadow .15s;display:flex}.die:active{transform:scale(.92)}.die.selected{border-color:var(--text-bright);box-shadow:0 0 8px #fff6}.die.used{opacity:.4;cursor:not-allowed}.die.color-die{background:var(--surface-2);color:var(--text)}.die.color-die[data-face=green]{background:var(--green);color:var(--green-dark)}.die.color-die[data-face=orange]{background:var(--orange);color:var(--orange-dark)}.die.color-die[data-face=yellow]{background:var(--yellow);color:var(--yellow-dark)}.die.color-die[data-face=blue]{background:var(--blue);color:var(--blue-dark)}.die.color-die[data-face=pink]{background:var(--pink);color:var(--pink-dark)}.die.color-die[data-face=wild]{background:linear-gradient(135deg, var(--green), var(--orange), var(--yellow), var(--blue), var(--pink));color:#fff}.die.number-die{background:var(--surface-2);color:var(--text-bright)}.die.number-die[data-face=wild]{background:linear-gradient(135deg, var(--surface-3), var(--surface-2));color:var(--text-bright)}.die.special-die{color:#5a4020;background:#c8a050}.die.special-die.selected{background:#d8b060;border-color:#8a6020;box-shadow:0 0 10px #c8a05066}.special-badge{color:#5a4020;text-transform:uppercase;letter-spacing:1px;background:#c8a050;border-radius:4px;padding:2px 8px;font-size:9px;font-weight:700}.btn{cursor:pointer;text-transform:uppercase;letter-spacing:1px;-webkit-tap-highlight-color:transparent;border:none;border-radius:6px;width:100%;padding:8px 16px;font-size:12px;font-weight:700;transition:transform .1s,opacity .1s}.btn:active{transform:scale(.95)}.btn:disabled{opacity:.3;cursor:not-allowed}.btn-confirm{background:var(--green);color:var(--green-dark)}.btn-pass{background:var(--surface-2);color:var(--text)}.btn-new{background:var(--accent);color:#fff}.opp-legend{justify-content:center;align-items:center;gap:8px;padding:2px 0;display:flex}.opp-legend-item{color:var(--text-dim);align-items:center;gap:3px;font-size:10px;display:flex}.opp-legend-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.game-over{z-index:100;background:#f0e8d8eb;flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex;position:fixed;inset:0}.game-over h2{color:var(--text-bright);font-size:28px;font-weight:800}.game-over .final-score{color:var(--accent);font-size:52px;font-weight:900}.game-over .rating{color:var(--text);font-size:16px}@keyframes dice-roll{0%{transform:rotateX(0)rotateY(0)rotate(0)scale(1)}15%{transform:rotateX(120deg)rotateY(60deg)rotate(30deg)scale(.7)}30%{transform:rotateX(240deg)rotateY(180deg)rotate(90deg)scale(1.2)}50%{transform:rotateX(400deg)rotateY(320deg)rotate(180deg)scale(.75)}70%{transform:rotateX(560deg)rotateY(520deg)rotate(270deg)scale(1.15)}85%{transform:rotateX(660deg)rotateY(660deg)rotate(330deg)scale(.9)}to{transform:rotateX(720deg)rotateY(720deg)rotate(360deg)scale(1)}}.die.rolling{animation:.6s cubic-bezier(.25,.46,.45,.94) dice-roll;box-shadow:0 6px 16px #00000080}@keyframes dice-land{0%{transform:scale(1.2)translateY(-3px);box-shadow:0 6px 14px #0006}35%{transform:scale(.92)translateY(1px);box-shadow:0 1px 4px #0000004d}65%{transform:scale(1.05)translateY(-1px);box-shadow:0 3px 8px #0003}to{box-shadow:none;transform:scale(1)translateY(0)}}.die.landed{animation:.35s cubic-bezier(.34,1.56,.64,1) dice-land}@keyframes pulse-dim{0%,to{opacity:.6}50%{opacity:1}}.waiting-badge{background:var(--surface);color:var(--text-dim);text-align:center;border-radius:6px;padding:6px 14px;font-size:11px;font-weight:600;animation:2s ease-in-out infinite pulse-dim}.speed-count{width:var(--cell);height:var(--cell);font-size:calc(var(--cell) * .4);color:var(--accent);justify-content:center;align-items:center;font-weight:700;display:flex}.menu-screen,.lobby-screen{background:var(--bg);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.menu-content,.lobby-content{flex-direction:column;align-items:center;gap:16px;width:100%;max-width:360px;padding:24px;display:flex}.menu-title{color:var(--text-bright);letter-spacing:3px;text-transform:uppercase;font-size:32px;font-weight:900}.menu-sub{color:var(--text-dim);margin-top:-8px;font-size:13px}.menu-name{width:100%}.menu-input{border:1px solid var(--surface-2);background:var(--surface);width:100%;color:var(--text-bright);text-align:center;border-radius:6px;outline:none;padding:10px 14px;font-family:inherit;font-size:14px}.menu-input:focus{border-color:var(--accent)}.menu-input::placeholder{color:var(--text-dim)}.code-input{letter-spacing:6px;text-transform:uppercase;font-size:20px;font-weight:700}.menu-buttons{gap:8px;width:100%;display:flex}.btn-menu{flex:1;padding:14px 12px;font-size:13px}.btn-solo{background:var(--green);color:var(--green-dark)}.btn-create{background:var(--accent);color:#fff}.btn-join{background:var(--surface-2);color:var(--text)}.menu-join{align-items:center;gap:8px;width:100%;display:flex}.menu-join .menu-input{flex:1}.btn-go{background:var(--accent);color:#fff;width:auto;padding:10px 20px}.lobby-title{color:var(--text-bright);text-transform:uppercase;letter-spacing:2px;font-size:22px;font-weight:800}.lobby-code{flex-direction:column;align-items:center;gap:4px;display:flex}.code-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;font-size:11px}.code-value{letter-spacing:8px;color:var(--accent);font-size:32px;font-weight:900}.lobby-share{width:100%}.btn-share{background:var(--surface-2);color:var(--text)}.lobby-players{background:var(--surface);border-radius:8px;width:100%;padding:12px}.lobby-players h3{color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;font-size:11px}.lobby-player{color:var(--text);align-items:center;gap:8px;padding:6px 0;font-size:14px;display:flex}.lobby-player.me{color:var(--text-bright);font-weight:700}.player-dot{background:var(--green);border-radius:50%;flex-shrink:0;width:8px;height:8px}.lobby-waiting{color:var(--text-dim);text-align:center;padding:8px 0;font-size:12px}.lobby-actions{flex-direction:column;gap:8px;width:100%;display:flex}.btn-start{background:var(--green);color:var(--green-dark)}.btn-leave{background:var(--surface-2);color:var(--text-dim);font-size:11px}.leaderboard{background:var(--surface);border-radius:8px;width:240px;padding:8px 12px}.lb-row{color:var(--text);align-items:center;gap:8px;padding:4px 0;font-size:14px;display:flex}.lb-row.me{color:var(--accent);font-weight:700}.lb-rank{width:24px;color:var(--text-dim);font-weight:700}.lb-name{flex:1}.lb-score{font-weight:800}.install-banner{background:var(--surface);color:var(--text);z-index:200;border-top:1px solid var(--surface-2);justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;font-size:12px;display:flex;position:fixed;bottom:0;left:0;right:0}.install-banner button{color:var(--text-dim);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;padding:4px 8px;font-size:16px}
