:root{--felt-1: #0f6b41;--felt-2: #062b1a;--felt-edge: #03180e;--gold: #e7c466;--gold-deep: #a07e2c;--gold-dim: #6a5320;--ivory: #f5ecd6;--card-bg: linear-gradient(180deg, #fdfaf3 0%, #f3eada 100%);--card-border: #5b4b1f;--back-1: #8a1a1a;--back-2: #4b0d0d;--shadow: 0 4px 10px rgba(0, 0, 0, .45);--shadow-lift: 0 10px 22px rgba(0, 0, 0, .55);--card-w: 56px;--card-h: 80px;--card-w-sm: 40px;--card-h-sm: 58px;--card-w-yours: 82px;--card-h-yours: 118px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0;overflow:hidden}body{font-family:Segoe UI,system-ui,-apple-system,Helvetica Neue,Arial,sans-serif;color:var(--ivory);background:var(--felt-edge);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;overscroll-behavior:none}.app{display:flex;flex-direction:column;height:100%;padding:env(safe-area-inset-top,0) env(safe-area-inset-right,0) env(safe-area-inset-bottom,0) env(safe-area-inset-left,0);background:radial-gradient(ellipse at center,var(--felt-1) 0%,var(--felt-2) 65%,var(--felt-edge) 100%)}.topbar{flex:0 0 auto;display:flex;justify-content:space-between;align-items:center;gap:12px;padding:8px 12px;background:linear-gradient(180deg,#00000073,#0000)}.score-block{display:flex;gap:8px}.score-team{display:flex;flex-direction:column;align-items:flex-start;min-width:78px;padding:4px 10px;border-radius:8px;background:#0000004d;border:1px solid var(--gold-dim);line-height:1.1}.score-team--us{border-color:var(--gold)}.score-team__label{font-size:10px;letter-spacing:1.2px;color:var(--gold);text-transform:uppercase}.score-team__points{font-size:22px;font-weight:700;color:var(--ivory);font-variant-numeric:tabular-nums}.score-team__match{font-size:10px;color:var(--ivory);opacity:.65}.pente{color:var(--gold);display:block;filter:drop-shadow(0 1px 0 rgba(0,0,0,.45));font-family:Georgia,Times New Roman,serif;font-style:italic}.trump-block{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:8px;background:#0000004d;border:1px solid var(--gold);box-shadow:0 0 12px #e7c46633}.trump-block__label{font-size:10px;letter-spacing:1.2px;color:var(--gold);text-transform:uppercase}.trump-block__name{font-size:11px;color:var(--ivory);opacity:.9}.trump-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:8px;background:#00000059;border:1px solid var(--gold);box-shadow:0 0 10px #e7c46633;font-family:Georgia,Times New Roman,serif;white-space:nowrap}.trump-chip__label{font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--gold);opacity:.85}.trump-chip__rank{font-size:14px;font-weight:800;color:var(--ivory)}.trump-chip__suit{font-size:18px;font-weight:700;line-height:1;width:22px;height:22px;border-radius:50%;background:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 0 0 1px #0003}@media (max-width: 380px){.trump-chip__label{display:none}}.table{flex:1 1 auto;position:relative;display:grid;grid-template-columns:minmax(48px,auto) 1fr minmax(48px,auto);grid-template-rows:auto 1fr auto;grid-template-areas:"n n n" "w c e" "s s s";padding:8px;min-height:0;gap:4px}.seat{display:flex;align-items:center;justify-content:center;min-width:0;min-height:0}.seat--n{grid-area:n;align-items:flex-start;padding-top:4px}.seat--s{grid-area:s;align-items:flex-end;padding-bottom:4px}.seat--w{grid-area:w}.seat--e{grid-area:e}.fan{display:flex}.fan--row{flex-direction:row;align-items:flex-end;justify-content:center}.fan--col{flex-direction:column;align-items:center;justify-content:center}.fan__slot{display:flex;align-items:center;justify-content:center}.fan--row:not(.fan--your) .fan__slot{margin-left:-22px}.fan--row .fan__slot:first-child{margin-left:0}.fan--col .fan__slot{margin-top:-42px}.fan--col .fan__slot:first-child{margin-top:0}.fan--your .fan__slot:first-child{margin-left:0}.face-down{display:flex;align-items:center;gap:6px}.face-down--row,.face-down--col{flex-direction:column}.seat-name{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--ivory);opacity:.7;text-align:center}.seat-name--turn{color:var(--gold);opacity:1;text-shadow:0 0 6px rgba(231,196,102,.6)}.face-down--turn .fan__slot .card--back{box-shadow:0 0 0 2px var(--gold),var(--shadow)}.fan__slot--trump{position:relative}.fan__slot--trump .card--face,.fan__slot--trump .card--back{box-shadow:0 0 0 3px var(--gold),0 0 18px #e7c466bf,var(--shadow)}.trump-badge{position:absolute;top:-10px;left:50%;transform:translate(-50%);background:var(--gold);color:#2a1d00;font-size:9px;font-weight:800;letter-spacing:1px;text-transform:uppercase;padding:2px 7px;border-radius:999px;white-space:nowrap;box-shadow:0 2px 4px #0006;z-index:5;pointer-events:none}.your-hand{width:100%;display:flex;flex-direction:column;align-items:center;gap:4px}.your-hand__header{display:flex;align-items:center;justify-content:center;gap:8px}.your-hand__align{background:#0000004d;color:var(--ivory);border:1px solid var(--gold-dim);width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;line-height:1;padding:0}.your-hand__align:hover,.your-hand__align:focus-visible{border-color:var(--gold);color:var(--gold)}.seat-name--you{font-size:12px;color:var(--ivory)}.fan--arc{padding-top:14px}.fan--arc .fan__slot{transform-origin:50% 180%;transition:transform .2s cubic-bezier(.2,.7,.2,1)}.your-hand .card--md,.trick-slot .card--md,.face-down .card--md{width:var(--card-w-yours);height:var(--card-h-yours);border-radius:9px}.your-hand .card__rank,.trick-slot .card__rank{font-size:19px}.your-hand .card__suit,.trick-slot .card__suit{font-size:15px}.your-hand .card__center,.trick-slot .card__center{font-size:40px}.your-hand .card__corner--tl,.trick-slot .card__corner--tl{top:5px;left:6px}.your-hand .card__corner--br,.trick-slot .card__corner--br{bottom:5px;right:6px}.face-down .fan.fan--row .fan__slot{margin-left:var(--side-overlap-x, calc(var(--card-w-yours) * -.82))}.face-down .fan.fan--row .fan__slot:first-child{margin-left:0}.face-down .fan.fan--col .fan__slot{margin-top:calc(var(--card-h-yours) * -.8)}.face-down .fan.fan--col .fan__slot:first-child{margin-top:0}.card{position:relative;width:var(--card-w);height:var(--card-h);border-radius:7px;border:1.5px solid var(--card-border);box-shadow:var(--shadow);padding:0;font-family:Georgia,Times New Roman,serif;font-weight:700;cursor:pointer;display:block;transition:transform .18s cubic-bezier(.2,.7,.2,1),box-shadow .18s ease,filter .18s ease}.card--face{background:var(--card-bg);color:#111}.card--sm{width:var(--card-w-sm);height:var(--card-h-sm);border-radius:5px;border-width:1px}.card--md{width:var(--card-w);height:var(--card-h)}.card--lg{width:72px;height:104px}.card--disabled{filter:brightness(.55) saturate(.6);cursor:default}.card--highlight:not(.card--disabled){box-shadow:0 0 0 2px var(--gold),0 6px 14px #0000008c}.card--highlight:not(.card--disabled):hover,.card--highlight:not(.card--disabled):focus-visible{transform:translateY(-14px);box-shadow:0 0 0 2px var(--gold),var(--shadow-lift)}.trick-slot--s .card--played{animation:card-from-s .42s cubic-bezier(.22,.9,.36,1) both}.trick-slot--n .card--played{animation:card-from-n .42s cubic-bezier(.22,.9,.36,1) both}.trick-slot--w .card--played{animation:card-from-w .42s cubic-bezier(.22,.9,.36,1) both}.trick-slot--e .card--played{animation:card-from-e .42s cubic-bezier(.22,.9,.36,1) both}@keyframes card-from-s{0%{transform:translateY(140px) scale(.75);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes card-from-n{0%{transform:translateY(-110px) scale(.75);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes card-from-w{0%{transform:translate(-110px) scale(.75);opacity:0}to{transform:translate(0) scale(1);opacity:1}}@keyframes card-from-e{0%{transform:translate(110px) scale(.75);opacity:0}to{transform:translate(0) scale(1);opacity:1}}.card__corner{position:absolute;display:flex;flex-direction:column;align-items:center;line-height:1}.card__corner--tl{top:4px;left:5px}.card__corner--br{bottom:4px;right:5px;transform:rotate(180deg)}.card__rank{font-size:15px;font-weight:800}.card__suit{font-size:12px;margin-top:1px}.card__center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:30px;opacity:.9}.card__compact{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1;gap:2px}.card__compact-rank{font-size:15px;font-weight:800}.card__compact-suit{font-size:19px}@media (max-height: 700px){.card__compact-rank{font-size:13px}.card__compact-suit{font-size:17px}}@media (max-height: 580px){.card__compact-rank{font-size:12px}.card__compact-suit{font-size:15px}}@media (min-width: 600px){.card__compact-rank{font-size:18px}.card__compact-suit{font-size:24px}}.card--back{background:repeating-linear-gradient(45deg,var(--back-1) 0px,var(--back-1) 4px,var(--back-2) 4px,var(--back-2) 8px);border-color:#2a0606;cursor:default}.card__back-frame{position:absolute;top:4px;right:4px;bottom:4px;left:4px;border:1px solid var(--back-frame, var(--gold));border-radius:4px;pointer-events:none}.card__back-emblem{position:absolute;top:4px;right:4px;bottom:4px;left:4px;display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--back-emblem-color, var(--gold));text-shadow:0 1px 2px rgba(0,0,0,.6);background-image:var(--back-emblem-img, none);background-size:50%;background-position:center;background-repeat:no-repeat}.card__back-emblem:before{content:var(--back-emblem, "♣")}.card--sm .card__back-emblem{font-size:16px}.trick-area{grid-area:c;position:relative;display:flex;align-items:center;justify-content:center;min-width:0;min-height:0;--trick-x: 52px;--trick-y: 60px;--trick-scale: 1}.trick-slot{position:absolute;top:50%;left:50%;--tx: 0px;--ty: 0px;--scale: 1;transform:translate(calc(-50% + var(--tx)),calc(-50% + var(--ty))) scale(var(--scale));display:flex;align-items:center;justify-content:center;transition:transform .25s ease,filter .25s ease}.trick-slot--n{--ty: calc(var(--trick-y) * -1)}.trick-slot--s{--ty: var(--trick-y)}.trick-slot--w{--tx: calc(var(--trick-x) * -1)}.trick-slot--e{--tx: var(--trick-x)}.trick-slot.is-winner{--scale: 1.1;filter:drop-shadow(0 0 10px var(--gold));z-index:4}.trick-center{position:absolute;top:4px;left:50%;transform:translate(-50%);display:flex;align-items:center;justify-content:center;text-align:center;pointer-events:none;z-index:5}.turn-indicator{display:flex;align-items:center;gap:5px;font-size:11px;letter-spacing:1px;text-transform:uppercase;padding:5px 11px;border-radius:999px;background:#0000008c;border:1px solid var(--gold-dim);color:var(--ivory);animation:turn-fade-in .25s ease both;white-space:nowrap}@keyframes turn-fade-in{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.turn-indicator--you{background:var(--gold);color:#2a1d00;border-color:var(--gold);font-weight:800;animation:pulse 1.4s ease-in-out infinite}.turn-indicator--waiting{opacity:.5}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 0 #e7c466b3}50%{transform:scale(1.06);box-shadow:0 0 0 8px #e7c46600}}.trick-result{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 14px;border-radius:10px;background:#0000008c;border:1px solid var(--gold);font-size:13px;font-weight:600;letter-spacing:.3px}.trick-result--us{border-color:var(--gold);box-shadow:0 0 14px #e7c46673}.trick-result--them{border-color:#833}.trick-result__points{font-size:18px;font-weight:800;color:var(--gold)}.deal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:90;pointer-events:none}.deal-deck{position:absolute;transform:translate(-50%,-50%);width:var(--card-w);height:var(--card-h);transition:left .27s ease,top .27s ease}.deal-cb{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:7px;background:linear-gradient(145deg,var(--back-1) 0%,var(--back-2) 100%);border:1.5px solid rgba(255,255,255,.18);box-shadow:0 3px 8px #00000080}.deal-cb:after{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border-radius:3px;border:1px solid rgba(255,255,255,.1)}.deal-riffle--l{animation:deal-riffle-l .57s cubic-bezier(.4,0,.2,1) 2 both}.deal-riffle--r{animation:deal-riffle-r .57s cubic-bezier(.4,0,.2,1) 2 both}@keyframes deal-riffle-l{0%{transform:translate(0) rotate(0)}35%{transform:translate(-24px) rotate(-8deg)}70%{transform:translate(-8px) rotate(-2deg)}to{transform:translate(0) rotate(0)}}@keyframes deal-riffle-r{0%{transform:translate(0) rotate(0)}35%{transform:translate(24px) rotate(8deg)}70%{transform:translate(8px) rotate(2deg)}to{transform:translate(0) rotate(0)}}.deal-cut-top{animation:deal-cut .32s ease both}@keyframes deal-cut{0%{transform:translate(0)}40%{transform:translate(32px,-6px)}75%{transform:translate(32px,-6px)}to{transform:translate(0)}}.deal-fly{position:absolute;width:var(--card-w);height:var(--card-h);border-radius:7px;transform:translate(-50%,-50%);background:linear-gradient(145deg,var(--back-1) 0%,var(--back-2) 100%);border:1.5px solid rgba(255,255,255,.18);box-shadow:0 3px 8px #00000080;animation:deal-fly-card linear forwards}.deal-fly:after{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border-radius:3px;border:1px solid rgba(255,255,255,.1)}@keyframes deal-fly-card{0%{transform:translate(-50%,-50%) scale(1);opacity:1}75%{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(.88);opacity:1}to{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(.88);opacity:0}}.table--dealing .face-down,.table--dealing .your-hand{visibility:hidden}.table--deal-reveal .face-down,.table--deal-reveal .your-hand{animation:deal-hands-in .35s ease both}@keyframes deal-hands-in{0%{opacity:0}to{opacity:1}}.modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;animation:fade-in .2s ease both}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:linear-gradient(180deg,var(--felt-1, #0e6b41) 0%,var(--felt-2, #074628) 100%);border:2px solid var(--gold);border-radius:14px;padding:22px 26px;min-width:260px;max-width:90%;text-align:center;box-shadow:0 14px 36px #000000a6;animation:pop-in .25s cubic-bezier(.2,.7,.2,1) both}@keyframes pop-in{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.modal__title{margin:0 0 4px;color:var(--gold);font-size:18px;letter-spacing:1.2px;text-transform:uppercase}.modal__result{margin:0 0 10px;font-size:15px}.modal__scores{display:flex;justify-content:space-around;margin:8px 0 10px;gap:12px}.modal__col{display:flex;flex-direction:column;align-items:center;flex:1;padding:6px 8px;border-radius:8px;background:#0000004d}.modal__col-label{font-size:11px;color:var(--gold);letter-spacing:1px;text-transform:uppercase}.modal__col-points{font-size:22px;font-weight:800;color:var(--ivory);font-variant-numeric:tabular-nums}.modal__match{font-size:12px;margin:0 0 14px;opacity:.85}.modal__winner{margin:6px 0 12px;font-size:18px}.modal__winner--us{color:var(--gold)}.modal__winner--them{color:#f7c0c0}.modal--match-over{text-align:center}.match-over__icon{font-size:56px;line-height:1;margin:4px 0 6px;filter:drop-shadow(0 4px 10px rgba(0,0,0,.45))}.match-over__title{font-size:26px;margin:0 0 8px}.match-over__title--us{color:var(--gold);text-shadow:0 0 12px rgba(231,196,102,.5)}.match-over__title--them{color:#f7c0c0}.match-over__score{display:flex;align-items:baseline;justify-content:center;gap:14px;margin:6px 0 4px;font-variant-numeric:tabular-nums}.match-over__num{font-size:44px;font-weight:800;color:var(--ivory)}.match-over__sep{font-size:28px;color:var(--gold);opacity:.7}.match-over__sub{font-size:12px;margin:0 0 16px;opacity:.8}.btn{background:var(--gold);color:#2a1d00;border:none;padding:10px 22px;border-radius:8px;font-size:14px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;cursor:pointer;font-family:inherit;box-shadow:0 4px 10px #00000073}.btn:hover,.btn:focus-visible{filter:brightness(1.08)}.btn:active{transform:translateY(1px)}.btn--ghost{background:transparent;color:var(--ivory);border:1px solid var(--gold-dim);text-transform:none;letter-spacing:.3px;font-weight:600}.btn--ghost:hover{border-color:var(--gold)}.btn--danger{background:#c44848;color:#fff}.iconbtn{background:#0000004d;color:var(--ivory);border:1px solid var(--gold-dim);width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;padding:0;flex-shrink:0}.iconbtn:hover{border-color:var(--gold);color:var(--gold)}.iconbtn--gear{font-size:18px}.multi-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:#00000059;border:1px solid var(--gold);color:var(--gold);font-family:inherit;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;box-shadow:0 0 10px #e7c4662e;flex-shrink:0}.multi-btn:hover{background:var(--gold);color:#2a1d00}.multi-btn__icon{font-size:14px}.multi-btn__label{letter-spacing:1px}.modal--settings{width:min(360px,92vw);height:min(620px,88vh);display:flex;flex-direction:column;padding:0;overflow:hidden}.settings__header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 6px}.settings__header .modal__title{margin:0}.settings__tabs{display:flex;gap:6px;padding:0 12px;height:48px;flex:0 0 48px;box-sizing:border-box;overflow:hidden;position:relative;z-index:2;border-bottom:1px solid rgba(255,255,255,.22);box-shadow:0 4px 8px #00000040;justify-content:center;align-items:center}.tab{background:transparent;color:var(--ivory);border:1px solid var(--gold-dim);border-radius:999px;padding:0 14px;font-family:inherit;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;letter-spacing:.3px;flex-shrink:0;line-height:1;display:inline-flex;align-items:center;justify-content:center;height:30px}.tab--active{background:var(--gold);color:#2a1d00;border-color:var(--gold)}.settings__body{padding:16px 18px;overflow-y:auto;flex:1 1 auto;min-height:0;position:relative;z-index:1}.settings__footer{display:flex;gap:8px;align-items:center;justify-content:flex-end;flex-wrap:wrap;padding:10px 14px 14px;border-top:1px solid rgba(255,255,255,.08);background:#00000026}.settings__confirm{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px}.stats__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.stat{display:flex;flex-direction:column;align-items:center;padding:8px 6px;border-radius:8px;background:#00000040;border:1px solid var(--gold-dim);text-align:center}.stat__value{font-size:20px;font-weight:800;color:var(--ivory);font-variant-numeric:tabular-nums}.stat__label{font-size:10px;letter-spacing:.8px;text-transform:uppercase;color:var(--ivory);opacity:.75;margin-top:2px}.stats__progress{margin-top:14px;font-size:12px;display:flex;flex-direction:column;gap:6px}.progressbar{height:6px;width:100%;background:#0006;border-radius:999px;overflow:hidden}.progressbar__fill{height:100%;background:linear-gradient(90deg,var(--gold-dim),var(--gold));transition:width .3s ease}.stats__reset{margin-top:18px;display:flex;justify-content:flex-end}.style-pane{display:flex;flex-direction:column;gap:18px}.style-pane__heading{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);margin:0 0 8px}.modal__actions{display:flex;flex-direction:column;gap:10px;margin:8px 0 12px;align-items:stretch}.modal__action-primary,.modal__action-secondary{width:100%;min-height:44px;display:inline-flex;align-items:center;justify-content:center}.picker__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.picker__item{background:#0003;border:1px solid var(--gold-dim);border-radius:10px;padding:10px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;font-family:inherit;color:var(--ivory);position:relative}.picker__item:hover:not(:disabled){border-color:var(--gold)}.picker__item--active{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold)}.picker__item--locked{opacity:.5;cursor:not-allowed}.picker__name{font-size:12px;font-weight:600}.picker__lock{position:absolute;top:4px;right:6px;font-size:11px;background:#0000008c;padding:2px 6px;border-radius:999px;color:var(--gold)}.picker__hint{margin:10px 0 0;font-size:12px;opacity:.75;text-align:center}.cardback-preview{display:inline-block;line-height:0}.table-preview{width:70px;height:50px;border-radius:10px;border:1.5px solid var(--gold)}.sound{display:flex;flex-direction:column;gap:10px}.toggle{display:flex;align-items:center;gap:10px;font-size:14px;cursor:pointer}.toggle input{width:18px;height:18px;accent-color:var(--gold)}.toggle--locked{opacity:.55;cursor:not-allowed}.toggle--locked input{cursor:not-allowed}.dev-unlock-row{display:flex;flex-direction:column;gap:4px;padding:8px 0 2px;border-top:1px dashed rgba(231,196,102,.25)}.dev-unlock-row__label{font-size:13px;color:var(--gold);opacity:.8}.dev-unlock-row__controls{display:flex;align-items:center;gap:8px}.dev-unlock-row__input{width:70px;padding:4px 8px;background:#00000080;border:1px solid var(--gold-dim);border-radius:6px;color:var(--ivory);font-family:inherit;font-size:14px;font-variant-numeric:tabular-nums}.dev-unlock-row__input:focus{outline:none;border-color:var(--gold)}.premium-badge{margin-left:auto;font-size:10px;letter-spacing:.8px;text-transform:uppercase;background:var(--gold);color:#2a1d00;padding:2px 7px;border-radius:999px;font-weight:800}.hint{font-size:12px;opacity:.7;margin:0}.length-picker{margin-top:14px;display:flex;flex-direction:column;gap:6px}.length-picker__label{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--gold);opacity:.8}.length-picker__options{display:flex;gap:8px}.length-picker__opt{position:relative;flex:1;background:#00000040;border:1px solid var(--gold-dim);color:var(--ivory);font-family:inherit;font-size:14px;font-weight:600;padding:10px 12px;border-radius:8px;cursor:pointer}.length-picker__opt:hover:not(:disabled){border-color:var(--gold)}.length-picker__opt--active{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold)}.length-picker__opt--locked{opacity:.6;cursor:not-allowed}.menu{flex:1 1 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px;text-align:center}.menu__title{margin:0;font-family:Georgia,Times New Roman,serif;font-size:56px;letter-spacing:6px;color:var(--gold);text-shadow:0 4px 18px rgba(0,0,0,.55);text-transform:uppercase}.menu__subtitle{margin:0 0 28px;font-size:14px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ivory);opacity:.7}.menu__actions{display:flex;flex-direction:column;gap:12px;width:min(280px,100%)}.menu__btn{padding:14px 22px;font-size:15px;display:inline-flex;align-items:center;justify-content:center;gap:8px}.menu__btn-icon{font-size:18px}.menu__btn--premium{background:linear-gradient(135deg,var(--gold),#c4a460);color:#2a1d00;box-shadow:0 4px 12px #e7c46673;border:none;padding:12px 22px;border-radius:8px;font-size:14px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;justify-content:center;gap:8px}.menu__btn--premium:disabled,.menu__btn--premium[aria-disabled=true]{filter:grayscale(.55);opacity:.7;cursor:not-allowed;box-shadow:none}.web-blocked-app{align-items:center;justify-content:center}.web-blocked{max-width:420px;text-align:center;padding:32px 24px;display:flex;flex-direction:column;align-items:center;gap:14px}.web-blocked__title{font-family:Georgia,Times New Roman,serif;font-size:44px;margin:0;color:var(--gold);letter-spacing:2px}.web-blocked__sub{margin:0;color:var(--ivory);opacity:.85;font-size:14px}.web-blocked__msg{margin:8px 0 4px;color:var(--ivory);font-size:15px;line-height:1.5}.web-blocked__cta{text-decoration:none;margin-top:4px}.menu__btn--restart{font-size:12px;padding:6px 14px;opacity:.8;align-self:center}.menu__confirm{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center;font-size:12px;padding:8px 12px;background:#00000040;border-radius:8px;align-self:center}.menu__btn-coming-soon{font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;background:#00000073;color:#fbe9b6;padding:2px 6px;border-radius:999px;margin-left:4px}.premium-error{margin:8px 0 0;font-size:13px;color:#ff9a9a;text-align:center}.premium-row{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.08)}.premium-expiry{font-size:12px;color:var(--ivory);opacity:.75}.premium-sale-banner{display:flex;align-items:center;gap:8px;margin-bottom:4px}.premium-sale-modal-banner{display:flex;flex-direction:column;align-items:center;gap:6px;margin:2px 0 12px}.premium-sale-pricing{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:700}.premium-sale-badge{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:2px 8px;border-radius:999px;background:#dc5a2840;border:1px solid rgba(220,110,50,.6);color:#f4a460;white-space:nowrap}.premium-original-price{font-size:13px;color:var(--ivory);opacity:.5;text-decoration:line-through}.premium-sale-arrow{color:#f4a460;opacity:.8}.premium-sale-price{color:#f4a460;font-size:17px}.promo-redeem{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.08)}.promo-redeem__label{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--gold);opacity:.85}.promo-redeem__row{display:flex;gap:8px;align-items:stretch}.promo-redeem__input{flex:1 1 auto;background:#00000059;border:1px solid var(--gold-dim);border-radius:8px;padding:10px 12px;color:var(--ivory);font-family:inherit;font-size:15px;letter-spacing:2px;text-transform:uppercase;min-width:0}.promo-redeem__input:focus{outline:none;border-color:var(--gold)}.promo-redeem__btn{white-space:nowrap}.promo-redeem__ok{margin:0;font-size:12px;color:var(--gold)}.promo-redeem__err{margin:0;font-size:12px;color:#f7a8a8}.badges__summary{text-align:center;margin:0 0 10px}.badges__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.badge{display:flex;flex-direction:column;align-items:center;text-align:center;padding:10px 8px;border-radius:10px;background:#00000040;border:1px solid var(--gold-dim)}.badge--earned{border-color:var(--gold);box-shadow:0 0 12px #e7c46633}.badge--locked{opacity:.55;filter:grayscale(.6)}.badge__emoji{font-size:32px;line-height:1;margin-bottom:4px}.badge__name{font-size:12px;font-weight:700;color:var(--ivory)}.badge__desc{font-size:10px;opacity:.75;margin-top:2px;line-height:1.3}.badge__progress{margin-top:6px}.badge__progress-text{font-size:9px;opacity:.7;font-variant-numeric:tabular-nums;margin-top:2px}.modal--badge{text-align:center}.badge-unlock{display:flex;justify-content:center;margin:4px 0 8px}.badge-unlock__emoji{font-size:80px;line-height:1;filter:drop-shadow(0 4px 18px rgba(231,196,102,.5));animation:badge-pop .55s cubic-bezier(.2,.7,.2,1) both}.badge-unlock__name{font-size:22px;font-weight:800;color:var(--gold);margin:0 0 4px}.badge-unlock__desc{font-size:13px;margin:0 0 16px;opacity:.9}@keyframes badge-pop{0%{transform:scale(.4) rotate(-12deg);opacity:0}60%{transform:scale(1.15) rotate(6deg);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}.menu__premium-tag{display:inline-block;margin-top:8px;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold)}.premium-perks{text-align:left;margin:12px 0 18px;padding-left:18px;font-size:14px;line-height:1.6;color:var(--ivory)}.premium-perks li{margin-bottom:2px}.debug-toast{position:fixed;left:50%;bottom:16px;transform:translate(-50%);background:#000000c7;color:var(--ivory);border:1px solid var(--gold);border-radius:999px;padding:8px 14px;font-size:12px;font-family:Segoe UI,system-ui,sans-serif;letter-spacing:.3px;max-width:90vw;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none;z-index:9999;animation:debug-toast-in .18s ease-out;margin-bottom:0}.debug-toast+.debug-toast{bottom:52px}.debug-toast+.debug-toast+.debug-toast{bottom:88px}.debug-toast+.debug-toast+.debug-toast+.debug-toast{bottom:124px}.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast{bottom:160px}.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast{bottom:196px}.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast{bottom:232px}.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast{bottom:268px}.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast{bottom:304px}.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast+.debug-toast{bottom:340px}.debug-toast--out{animation:debug-toast-out .28s ease-in forwards}@keyframes debug-toast-in{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}@keyframes debug-toast-out{0%{opacity:1}to{opacity:0;transform:translate(-50%,6px)}}.lobby{flex:1 1 auto;display:flex;flex-direction:column;min-height:0}.lobby__header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.08)}.lobby__title{margin:0;font-size:16px;letter-spacing:1.4px;text-transform:uppercase;color:var(--gold)}.lobby__body{flex:1 1 auto;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px;max-width:420px;margin:0 auto;width:100%}.lobby__field{display:flex;flex-direction:column;gap:4px}.lobby__field span{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--gold);opacity:.8}.lobby__field input{background:#00000059;border:1px solid var(--gold-dim);border-radius:8px;padding:10px 12px;color:var(--ivory);font-size:16px;font-family:inherit;letter-spacing:1px}.lobby__field input:focus{outline:none;border-color:var(--gold)}.lobby__field--error span{color:#ffb3b3;opacity:1}.lobby__field--error input{border-color:#f7c0c0;animation:lobby-field-shake .35s ease-in-out}.lobby__field-error{font-size:12px;color:#ffb3b3;letter-spacing:0;text-transform:none;margin-top:4px}@keyframes lobby-field-shake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(2px)}}.lobby__divider{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--ivory);opacity:.5;text-transform:uppercase;letter-spacing:1.5px}.lobby__divider:before,.lobby__divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.lobby__hint{font-size:11px;opacity:.6;line-height:1.5;margin:6px 0 0}.lobby__hint--quota{color:var(--gold);opacity:.9;text-align:center}.lobby__publish{margin-top:6px;align-self:stretch;justify-content:flex-start}.public-lobby{display:flex;flex-direction:column;gap:10px}.public-lobby__header{display:flex;align-items:baseline;justify-content:space-between}.public-lobby__refreshing{font-size:11px;opacity:.6}.public-lobby__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.public-lobby__item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;background:#00000040;border:1px solid var(--gold-dim);border-radius:10px}.public-lobby__meta{display:flex;flex-direction:column;min-width:0;flex:1 1 auto}.public-lobby__host{font-size:15px;font-weight:700;color:var(--ivory);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.public-lobby__sub{font-size:11px;opacity:.75;letter-spacing:.4px}.public-lobby__new-banner{align-self:center;padding:4px 12px;border-radius:999px;background:var(--gold);color:#2a1d00;font-size:11px;letter-spacing:1px;text-transform:uppercase;font-weight:800;animation:lobby-banner-in .3s cubic-bezier(.2,.7,.2,1)}.public-lobby__item--new{border-color:var(--gold);box-shadow:0 0 14px #e7c46659;animation:lobby-row-in .4s cubic-bezier(.2,.7,.2,1)}.public-lobby__new-badge{margin-left:8px;font-size:9px;font-weight:800;letter-spacing:1px;text-transform:uppercase;background:var(--gold);color:#2a1d00;padding:2px 6px;border-radius:999px;vertical-align:middle}@keyframes lobby-row-in{0%{transform:translate(-12px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes lobby-banner-in{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.public-room-toast{position:fixed;top:calc(env(safe-area-inset-top,0) + 8px);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:6px;max-width:min(380px,calc(100vw - 24px));background:#000000d1;border:1px solid var(--gold);border-radius:12px;padding:8px 10px 8px 14px;box-shadow:0 10px 24px #00000080,0 0 18px #e7c4664d;z-index:200;animation:public-room-toast-in .32s cubic-bezier(.2,.7,.2,1)}.public-room-toast__body{flex:1 1 auto;background:none;border:none;color:var(--ivory);text-align:left;display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;column-gap:10px;cursor:pointer;font-family:inherit;padding:0}.public-room-toast__label{font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--gold);grid-column:1 / 2;grid-row:1 / 2}.public-room-toast__host{font-size:14px;font-weight:700;color:var(--ivory);grid-column:1 / 2;grid-row:2 / 3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.public-room-toast__cta{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--gold);align-self:center;grid-column:2 / 3;grid-row:1 / 3}.public-room-toast__close{flex:0 0 auto;background:transparent;border:none;color:var(--ivory);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:6px;opacity:.7}.public-room-toast__close:hover{opacity:1}@keyframes public-room-toast-in{0%{transform:translate(-50%,-16px);opacity:0}to{transform:translate(-50%);opacity:1}}.room{display:flex;flex-direction:column;gap:14px}.room__code-block{background:#0006;border:1.5px dashed var(--gold);border-radius:12px;padding:14px;text-align:center}.room__code-label{display:block;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold)}.room__code{display:block;font-size:38px;font-weight:800;letter-spacing:8px;margin-top:4px;font-family:Georgia,serif}.room__share{margin-top:10px}.room__share-feedback{display:block;margin-top:6px;font-size:12px;color:var(--gold)}.room__status{text-align:center;font-size:13px;min-height:20px}.room__error{color:#f7a8a8}.room__players h3{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);margin:4px 0 6px}.room__players ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.room__players li{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#00000040;border:1px solid var(--gold-dim);border-radius:8px;font-size:14px}.room__players li.empty{opacity:.5;font-style:italic}.tag{font-size:10px;text-transform:uppercase;letter-spacing:1px;padding:2px 6px;border-radius:999px;background:#ffffff14}.tag--you{background:var(--gold);color:#2a1d00;font-weight:800}.tag--partner{background:#e7c46633;color:var(--gold);border:1px solid var(--gold);font-weight:700}.room__partner h3{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);margin:4px 0 6px}.room__partner-options{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.room__partner-opt{background:#0000004d;border:1px solid var(--gold-dim);color:var(--ivory);font-family:inherit;font-size:12px;padding:6px 10px;border-radius:999px;cursor:pointer}.room__partner-opt:hover{border-color:var(--gold)}.room__partner-opt--active{background:var(--gold);color:#2a1d00;border-color:var(--gold);font-weight:700}:root{--your-overlap: -44px}.fan--your .fan__slot{margin-left:var(--your-overlap)}@media (max-width: 480px){:root{--card-w: 48px;--card-h: 70px;--card-w-sm: 34px;--card-h-sm: 50px;--card-w-yours: 68px;--card-h-yours: 98px;--your-overlap: -36px}.fan--row:not(.fan--your) .fan__slot{margin-left:-18px}.fan--col .fan__slot{margin-top:-36px}.your-hand .card__rank,.trick-slot .card__rank{font-size:17px}.your-hand .card__suit,.trick-slot .card__suit{font-size:14px}.your-hand .card__center,.trick-slot .card__center{font-size:36px}.trick-area{--trick-x: 44px;--trick-y: 52px}}@media (max-width: 380px){:root{--card-w: 42px;--card-h: 62px;--card-w-sm: 30px;--card-h-sm: 44px;--card-w-yours: 60px;--card-h-yours: 86px;--your-overlap: -32px}.fan--row:not(.fan--your) .fan__slot{margin-left:-16px}.fan--col .fan__slot{margin-top:-32px}.card__center{font-size:22px}.card__rank{font-size:13px}.your-hand .card__rank,.trick-slot .card__rank{font-size:15px}.your-hand .card__suit,.trick-slot .card__suit{font-size:13px}.your-hand .card__center,.trick-slot .card__center{font-size:32px}.trick-area{--trick-x: 38px;--trick-y: 46px}}@media (max-height: 580px){:root{--card-w: 42px;--card-h: 62px;--card-w-yours: 62px;--card-h-yours: 90px;--your-overlap: -32px}.fan--row:not(.fan--your) .fan__slot{margin-left:-16px}.fan--col .fan__slot{margin-top:-32px}}@media (min-width: 600px){:root{--card-w: 68px;--card-h: 96px;--card-w-sm: 48px;--card-h-sm: 68px;--card-w-yours: 100px;--card-h-yours: 144px;--your-overlap: -52px}.fan--row:not(.fan--your) .fan__slot{margin-left:-28px}.fan--col .fan__slot{margin-top:-50px}.card__rank{font-size:17px}.card__suit{font-size:14px}.card__center{font-size:36px}.your-hand .card__rank,.trick-slot .card__rank{font-size:26px}.your-hand .card__suit,.trick-slot .card__suit{font-size:19px}.your-hand .card__center,.trick-slot .card__center{font-size:56px}.trick-area{--trick-x: 66px;--trick-y: 76px}}.tournament{flex:1;display:flex;flex-direction:column;padding:12px 16px env(safe-area-inset-bottom,16px);overflow:hidden;min-height:0}.tournament__topbar{display:flex;align-items:center;gap:12px;padding:4px 0 10px;border-bottom:1px solid var(--gold-dim);margin-bottom:12px}.tournament__title{margin:0;color:var(--gold);font-size:18px;letter-spacing:1px;text-transform:uppercase;flex:1}.tournament__progress{color:var(--ivory);font-size:13px;font-variant-numeric:tabular-nums;background:#00000059;border:1px solid var(--gold-dim);border-radius:999px;padding:3px 10px}.tournament__pages{display:flex;gap:6px;margin-bottom:10px}.tournament__page-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:7px 4px;background:#0000004d;border:1px solid var(--gold-dim);border-radius:10px;color:var(--ivory);font-family:inherit;font-size:12px;cursor:pointer;opacity:.65;transition:opacity .15s,border-color .15s}.tournament__page-tab:hover{opacity:.85;border-color:var(--gold)}.tournament__page-tab--active{opacity:1;border-color:var(--gold);background:#7a4b0c47}.tournament__page-tab-label{font-weight:700;letter-spacing:.4px;text-transform:uppercase;font-size:11px}.tournament__page-tab-count{font-size:11px;font-variant-numeric:tabular-nums;opacity:.8}.tournament__list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:4px 2px 12px}.tournament__tile{display:grid;grid-template-columns:36px 1fr auto;align-items:center;gap:12px;width:100%;background:#00000059;border:1px solid var(--gold-dim);border-radius:12px;padding:12px 14px;color:var(--ivory);font-family:inherit;font-size:14px;text-align:left;cursor:pointer;transition:border-color .15s,transform .12s}.tournament__tile:hover:not(:disabled){border-color:var(--gold)}.tournament__tile:active:not(:disabled){transform:translateY(1px)}.tournament__tile-index{width:32px;height:32px;border-radius:50%;border:1px solid var(--gold-dim);display:inline-flex;align-items:center;justify-content:center;color:var(--gold);font-weight:700;font-variant-numeric:tabular-nums}.tournament__tile-body{display:flex;flex-direction:column;gap:2px;min-width:0}.tournament__tile-name{font-weight:700;letter-spacing:.3px}.tournament__tile-meta{font-size:12px;opacity:.85}.tournament__tile-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.tournament__tile-status{font-size:18px;color:var(--gold);line-height:1}.tournament__access-tag{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:1px 6px;border-radius:999px;border:1px solid;white-space:nowrap}.tournament__access-tag--free{color:#6fdc9c;border-color:#60c8848c;background:#306e4633}.tournament__access-tag--premium{color:var(--gold);border-color:#e7c46673;background:#7a4b0c2e}.tournament__tile--completed{border-color:#60c8848c;background:#306e4652}.tournament__tile--completed .tournament__tile-status{color:#6fdc9c}.tournament__tile--current{border-color:var(--gold);box-shadow:0 0 0 1px #e7c46659}.tournament__tile--boss{border-color:var(--gold);background:#7a4b0c52;box-shadow:0 0 18px #e7c46640}.tournament__tile--locked{opacity:.45;cursor:pointer}.tournament__tile--locked:hover{opacity:.6;border-color:#e7c46666}.tournament__tile--premium-locked{border-style:dashed;opacity:.85}.tournament__tile--active{outline:2px solid var(--gold);outline-offset:-1px}.modal--tournament{max-width:92%;width:min(420px,92vw);text-align:left}.tournament__modal-header-row{display:flex;justify-content:center;margin:4px 0 10px}.tournament__flavor{font-style:italic;opacity:.85;margin:0 0 14px;text-align:center}.tournament__matches{list-style:none;padding:0;margin:0 0 14px;display:flex;flex-direction:column;gap:6px}.tournament__match{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;padding:8px 10px;background:#0000004d;border:1px solid var(--gold-dim);border-radius:8px;font-size:13px}.tournament__match--current{border-color:var(--gold);background:#00000080}.tournament__match--past{opacity:.55}.tournament__match-label{font-weight:700;color:var(--gold);display:inline-flex;align-items:baseline;gap:6px}.tournament__match-final{font-size:10px;letter-spacing:1px;text-transform:uppercase;border:1px solid var(--gold);border-radius:999px;padding:1px 6px}.tournament__match-opps{font-size:12px;opacity:.9}.tournament__match-tier{font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:2px 6px;border-radius:999px;border:1px solid var(--gold-dim)}.tournament__match-tier--random{color:#b6e7c5;border-color:#60c8848c}.tournament__match-tier--rule{color:var(--ivory)}.tournament__match-tier--hard{color:#f1b370;border-color:#f1b3708c}.tournament__match-tier--boss{color:#ff9a9a;border-color:#ff9a9a99}.tournament__premium-hint{text-align:center;color:var(--gold)}.tournament__locked-hint{text-align:center;color:var(--ivory);opacity:.7;margin:0}.topbar__tournament{font-size:11px;letter-spacing:.6px;text-transform:uppercase;color:var(--gold);background:#00000059;border:1px solid var(--gold-dim);border-radius:999px;padding:3px 9px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.modal--tournament-complete .tournament-trophy{font-size:56px;margin-bottom:4px;text-shadow:0 0 18px rgba(231,196,102,.5)}@media (orientation: landscape) and (max-height: 520px){:root{--card-w: 38px;--card-h: 54px;--card-w-sm: 28px;--card-h-sm: 40px;--card-w-yours: 52px;--card-h-yours: 74px;--your-overlap: -22px}.app{padding:0 env(safe-area-inset-right,0) env(safe-area-inset-bottom,0) env(safe-area-inset-left,0)}.topbar{padding:4px 10px;gap:8px}.pente{transform:scale(.78);transform-origin:left center;margin-right:-28px}.trump-chip{font-size:11px;padding:2px 8px}.table{padding:2px;gap:2px;grid-template-rows:minmax(58px,auto) 1fr minmax(78px,auto)}.seat--n{padding-top:2px}.seat--s{padding-bottom:2px}.fan--row:not(.fan--your) .fan__slot{margin-left:-14px}.fan--col .fan__slot{margin-top:-44px}.face-down--col .seat-name,.face-down--row .seat-name{font-size:9px;letter-spacing:.6px}.your-hand{gap:2px}.seat-name--you{font-size:11px}.fan--arc{padding-top:8px}.your-hand .card--md,.trick-slot .card--md,.face-down .card--md{border-radius:6px}.your-hand .card__rank,.trick-slot .card__rank{font-size:14px}.your-hand .card__suit,.trick-slot .card__suit{font-size:11px}.your-hand .card__center,.trick-slot .card__center{font-size:26px}.trick-area{--trick-x: 40px;--trick-y: 40px}.modal{padding:14px 18px;min-width:220px;max-height:92vh;overflow-y:auto}.modal--settings{width:min(560px,96vw);height:min(94vh,460px)}.modal--tournament{width:min(560px,96vw)}.menu{padding:8px 16px;gap:4px}.menu__title{font-size:36px;letter-spacing:4px}.menu__subtitle{font-size:11px;margin-bottom:12px}.menu__actions{gap:8px;width:min(360px,100%)}.menu__btn{padding:10px 18px;font-size:13px}.tournament{padding:6px 12px}.tournament__topbar{padding:2px 0 4px;margin-bottom:6px;gap:8px}.tournament__title{font-size:14px}.tournament__progress{font-size:11px;padding:2px 8px}.tournament__pages{gap:4px;margin-bottom:6px}.tournament__page-tab{padding:5px 2px}.tournament__page-tab-label,.tournament__page-tab-count{font-size:10px}.tournament__list{gap:6px;padding:2px}.tournament__tile{padding:7px 10px;grid-template-columns:28px 1fr auto;gap:10px;font-size:13px}.tournament__tile-index{width:26px;height:26px;font-size:12px}.tournament__tile-name{font-size:13px}.tournament__tile-meta{font-size:11px}.tournament__tile-status{font-size:15px}.topbar__tournament{max-width:130px;font-size:10px}.settings__tabs{height:40px;flex:0 0 40px}.settings__header{padding:8px 14px 4px}.settings__footer{padding:8px 14px}}@media (orientation: landscape) and (max-height: 400px){:root{--card-w: 32px;--card-h: 46px;--card-w-yours: 44px;--card-h-yours: 62px;--your-overlap: -18px}.fan--row:not(.fan--your) .fan__slot{margin-left:-12px}.fan--col .fan__slot{margin-top:-38px}.trick-area{--trick-x: 32px;--trick-y: 32px}.your-hand .card__center,.trick-slot .card__center{font-size:22px}.menu__title{font-size:28px}}
