*,*:before,*:after{box-sizing:border-box}*{margin:0}:root{--felt: #176b47;--felt-deep: #0c3f2d;--felt-light: #21845c;--table-start: rgba(33, 119, 79, .9);--table-end: rgba(8, 55, 39, .9);--panel-start: rgba(29, 126, 86, .9);--panel-end: rgba(10, 67, 47, .92);--modal-start: rgba(33, 132, 92, .98);--modal-end: rgba(12, 63, 45, .98);--cream: #fffaf0;--ink: #172019;--muted: rgba(255, 255, 255, .72);--red-card: #c92735;--black-card: #161b22;--gold: #f3c45a;--gold-deep: #aa7928;--accent-contrast: #2f2106;--slot: rgba(255, 255, 255, .11);--slot-border: rgba(255, 255, 255, .28);--card-width: clamp(46px, 5.3vw, 86px);--card-height: calc(var(--card-width) * 1.55);--column-gap: clamp(10px, 1.4vw, 24px);--stack-gap: clamp(22px, 2.4vw, 32px);color:var(--cream);background:var(--felt-deep);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}body{min-width:320px;min-height:100dvh;overflow-x:hidden;background:linear-gradient(135deg,rgba(255,255,255,.055) 25%,transparent 25%) 0 0 / 28px 28px,linear-gradient(225deg,rgba(0,0,0,.08) 25%,transparent 25%) 0 0 / 28px 28px,radial-gradient(circle at 50% 0%,rgba(255,255,255,.16),transparent 42%),linear-gradient(145deg,var(--felt-light),var(--felt) 45%,var(--felt-deep));transition:background .18s ease}:root[data-theme=red]{--felt: #7e2230;--felt-deep: #351018;--felt-light: #bc4a58;--table-start: rgba(119, 32, 46, .9);--table-end: rgba(48, 13, 22, .92);--panel-start: rgba(137, 38, 52, .9);--panel-end: rgba(63, 18, 27, .94);--modal-start: rgba(129, 37, 51, .98);--modal-end: rgba(53, 16, 24, .98);--gold: #ffd166;--gold-deep: #b97822;--slot: rgba(255, 238, 238, .11);--slot-border: rgba(255, 226, 226, .32)}:root[data-theme=blue]{--felt: #145277;--felt-deep: #071f35;--felt-light: #2f8bb7;--table-start: rgba(22, 83, 121, .9);--table-end: rgba(7, 34, 57, .92);--panel-start: rgba(29, 100, 143, .9);--panel-end: rgba(9, 45, 76, .94);--modal-start: rgba(27, 94, 135, .98);--modal-end: rgba(7, 37, 64, .98);--gold: #f7c85f;--gold-deep: #a67322;--slot: rgba(233, 247, 255, .12);--slot-border: rgba(219, 243, 255, .34)}button{border:0;font:inherit}#root{min-height:100dvh;overflow-x:hidden}@media(max-width:720px){:root{--column-gap: clamp(5px, 1vw, 8px);--card-width: calc((100vw - 48px - (var(--column-gap) * 6)) / 7);--card-height: calc(var(--card-width) * 1.55);--stack-gap: clamp(22px, 6.4vw, 30px)}}@media(max-width:620px){:root{--column-gap: clamp(4px, 1.5vw, 7px);--card-width: calc((100vw - 24px - (var(--column-gap) * 6)) / 7);--stack-gap: clamp(23px, 7vw, 31px)}}.app-shell{display:grid;grid-template-rows:minmax(0,1fr);width:100%;height:100dvh;margin:0 auto;overflow:hidden;padding:0}.home-screen,.setup-screen{display:grid;min-height:100dvh;place-items:center;padding:24px;background:radial-gradient(ellipse at 50% 30%,var(--felt-light) 0%,var(--felt) 50%,var(--felt-deep) 100%)}.home-panel{display:flex;flex-direction:column;align-items:center;gap:0;text-align:center;width:min(440px,100%)}.home-card-fan{position:relative;width:220px;height:160px;margin-bottom:clamp(24px,4vh,40px)}.fan-card{position:absolute;bottom:0;left:50%;display:flex;flex-direction:column;align-items:flex-start;width:88px;height:132px;padding:8px 10px;border:1.5px solid rgba(255,255,255,.7);border-radius:10px;background:linear-gradient(160deg,#fffef9,#f5ead8);box-shadow:0 8px 24px #00000073,0 2px 4px #0003;font-size:1.5rem;font-weight:900;line-height:1;transform-origin:50% 95%}.fan-card-red{color:#c0152a;transform:translate(-108px) rotate(-18deg);z-index:0}.fan-card-black{color:#1a1a1a;transform:translate(20px) rotate(18deg);z-index:0}.fan-card-back{background:repeating-linear-gradient(45deg,rgba(255,255,255,.15) 0 5px,transparent 5px 10px),linear-gradient(145deg,#2248a0,#0e1f6b);border-color:#fff6;transform:translate(-44px) translateY(-10px);z-index:1}.home-suit-row{display:flex;gap:18px;align-items:center;justify-content:center;font-size:2.2rem;margin-bottom:clamp(10px,2vh,18px);filter:drop-shadow(0 4px 8px rgba(0,0,0,.4))}.home-suit-row .suit-red{color:#e0213a}.home-suit-row .suit-black{color:#d4c8a8}.home-panel h1{font-size:clamp(4rem,14vw,7rem);line-height:.9;color:#faf0d0;text-shadow:0 2px 0 rgba(0,0,0,.35),0 8px 32px rgba(0,0,0,.4);letter-spacing:-.02em;margin:0}.home-tagline{margin-top:clamp(10px,2vh,16px);color:#ffffff80;font-size:.72rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase}.home-actions{display:flex;flex-direction:column;gap:12px;width:100%;margin-top:clamp(28px,5vh,48px)}.home-actions .btn-primary{display:flex;align-items:center;justify-content:center;width:100%;height:58px;border-radius:12px;background:linear-gradient(180deg,#f5c842,#e8a820);box-shadow:0 5px #a8711a,0 8px 20px #0000004d;color:#2a1800;font-size:1.1rem;font-weight:900;letter-spacing:.04em;cursor:pointer;transition:transform 80ms ease,box-shadow 80ms ease}.home-actions .btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px #a8711a,0 10px 24px #00000059}.home-actions .btn-primary:active{transform:translateY(3px);box-shadow:0 2px #a8711a,0 4px 12px #0000004d}.home-actions .btn-secondary{display:flex;align-items:center;justify-content:center;width:100%;height:50px;border-radius:12px;background:#ffffff1a;box-shadow:inset 0 0 0 1.5px #ffffff38;color:#ffffffe0;font-size:1rem;font-weight:800;cursor:pointer;transition:background .12s ease}.home-actions .btn-secondary:hover{background:#ffffff29}.setup-panel{width:min(500px,100%);border:1px solid rgba(255,255,255,.14);border-radius:16px;padding:clamp(28px,5vw,48px);text-align:left;background:#00000047;box-shadow:0 32px 80px #0006;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.setup-panel>p{color:#ffffff80;font-size:.72rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;margin-bottom:8px}.setup-panel h1{font-size:clamp(2.2rem,8vw,3.4rem);color:#faf0d0;line-height:1;margin:0 0 28px;text-shadow:0 4px 16px rgba(0,0,0,.3)}.name-field{display:grid;gap:8px;margin-bottom:24px}.name-field span{color:#ffffffb3;font-size:.8rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.name-field input{min-height:50px;border:1.5px solid rgba(255,255,255,.18);border-radius:10px;padding:0 16px;color:#faf0d0;background:#ffffff14;outline:none;font:inherit;font-size:1.05rem;font-weight:700;transition:border-color .12s ease,background .12s ease}.name-field input:focus{border-color:#f5c842b3;background:#ffffff1f}.name-field input::placeholder{color:#ffffff4d}.theme-label{color:#ffffffb3;font-size:.8rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px}.theme-picker{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:32px}.theme-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:14px 10px;border-radius:10px;border:2px solid transparent;background:#ffffff12;color:#ffffffbf;font-size:.82rem;font-weight:800;text-transform:capitalize;cursor:pointer;transition:background .12s ease,border-color .12s ease}.theme-option:hover{background:#ffffff21}.theme-option.active{border-color:#f5c842;background:#f5c8421f;color:#faf0d0}.theme-swatch{width:42px;height:28px;border-radius:6px;border:1.5px solid rgba(255,255,255,.3);box-shadow:0 4px 10px #0000004d}.theme-swatch.green{background:linear-gradient(145deg,#2ba26f,#0c3f2d)}.theme-swatch.red{background:linear-gradient(145deg,#c44d5d,#42151d)}.theme-swatch.blue{background:linear-gradient(145deg,#39a0d0,#092b48)}.setup-actions{display:grid;grid-template-columns:auto 1fr;gap:10px}.setup-actions button{display:flex;align-items:center;justify-content:center;height:52px;border-radius:10px;font-size:1rem;font-weight:800;cursor:pointer;transition:background .12s ease}.setup-actions button:first-child{padding:0 24px;background:#ffffff1a;box-shadow:inset 0 0 0 1.5px #fff3;color:#fffc}.setup-actions button:first-child:hover{background:#ffffff29}.setup-actions button.primary{background:linear-gradient(180deg,#f5c842,#e8a820);box-shadow:0 4px #a8711a,0 6px 18px #0000004d;color:#2a1800;font-size:1.05rem}.setup-actions button.primary:hover{background:linear-gradient(180deg,#f8d060,#edba30)}@media(max-width:480px){.home-card-fan{width:180px;height:136px}.fan-card{width:74px;height:112px;font-size:1.3rem}.fan-card-red{transform:translate(-90px) rotate(-18deg)}.fan-card-black{transform:translate(16px) rotate(18deg)}.fan-card-back{transform:translate(-37px) translateY(-10px)}.theme-picker,.setup-actions{grid-template-columns:1fr}}.confirm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:20px;background:#04100aa3;-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px);z-index:110}.confirm-modal{width:min(430px,100%);border:1px solid rgba(255,255,255,.22);border-radius:8px;padding:clamp(22px,5vw,34px);color:var(--cream);background:radial-gradient(circle at 16% 0%,rgba(255,255,255,.14),transparent 40%),linear-gradient(145deg,var(--modal-start),var(--modal-end));box-shadow:0 30px 90px #0000006b}.confirm-modal p{color:var(--muted);font-size:.75rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.confirm-modal h2{margin-top:6px;font-size:clamp(2rem,8vw,3.3rem);line-height:.98}.confirm-modal>span{display:block;margin-top:12px;color:#ffffffc7;line-height:1.45}.confirm-actions{display:grid;grid-template-columns:1fr 2fr;gap:10px;margin-top:24px}.confirm-actions button{min-height:44px;border-radius:8px;cursor:pointer;color:var(--cream);background:#ffffff24;box-shadow:inset 0 0 0 1px #ffffff2e;font-weight:900}.confirm-actions .confirm-primary{color:var(--accent-contrast);background:var(--gold);box-shadow:0 4px 0 var(--gold-deep)}.card{position:relative;width:var(--card-width);height:var(--card-height);flex:0 0 auto;border-radius:8px;box-shadow:0 8px 16px #04150d3d}.card-face{display:grid;place-items:center;cursor:pointer;touch-action:none;background:#fff;color:var(--black-card);transition:transform .14s ease,box-shadow .14s ease}.card-face.red{color:var(--red-card)}.card-face:hover{transform:translateY(-2px);box-shadow:0 12px 22px #04150d4d}.card-face.dragging{opacity:.55}.touch-drag-preview{position:fixed;pointer-events:none;z-index:9999;opacity:.92;filter:drop-shadow(0 18px 28px rgba(0,0,0,.28))}.card-corner{position:absolute;display:grid;justify-items:center;gap:0;font-size:clamp(.7rem,1.6vw,1rem);font-weight:700;line-height:1}.card-corner.top{top:6px;left:7px}.card-corner.bottom{right:7px;bottom:6px;transform:rotate(180deg)}.card-suit{font-size:clamp(1.8rem,5.5vw,4rem);line-height:1;pointer-events:none}.trick-card-slot .card-suit{font-size:clamp(2.2rem,5.5vw,3.8rem)}.trick-card-slot .card-corner{font-size:clamp(1rem,2.2vw,1.6rem)}.trick-card-slot .card-corner.top{top:10px;left:10px}.trick-card-slot .card-corner.bottom{right:10px;bottom:10px}.card-back{display:grid;place-items:center;border:2px solid rgba(255,255,255,.85);background:linear-gradient(145deg,#1e4fa8,#0c2e78)}.card-back span{width:72%;height:76%;border:2px solid rgba(255,255,255,.7);border-radius:5px;background:linear-gradient(145deg,#1a47a0,#0a2870)}@media(max-width:620px){.card{border-radius:6px}.card-corner.top{top:5px;left:5px}.card-corner.bottom{right:5px;bottom:5px}}.hearts-board{position:relative;width:100%;height:100%;min-height:0;overflow:hidden;background:radial-gradient(ellipse at 50% 50%,var(--felt-light) 0%,var(--felt) 45%,var(--felt-deep) 100%)}.table-layout{position:relative;width:100%;height:100%}.opponent-seat{position:absolute;display:flex;align-items:center}.opponent-seat.north{top:0;left:50%;flex-direction:column;gap:0;width:min(1120px,82vw);transform:translate(-50%)}.north .opponent-hand{order:1;--card-width: clamp(92px, 8vw, 138px);--card-height: calc(var(--card-width) * 1.55);display:flex;flex-direction:row;justify-content:center;width:100%;height:var(--card-height);overflow:visible;margin-top:calc(var(--card-height) * -.5)}.north .seat-info{order:2;margin-top:6px}.opponent-seat.west{top:50%;left:0;flex-direction:row;gap:clamp(22px,3vw,42px);transform:translateY(-50%)}.west .opponent-hand{order:1;margin-left:calc(var(--card-height) * -.5)}.west .seat-info{order:2;flex-direction:column;gap:6px}.opponent-seat.east{top:50%;right:0;flex-direction:row-reverse;gap:clamp(22px,3vw,42px);transform:translateY(-50%)}.east .opponent-hand{order:1;margin-right:calc(var(--card-height) * -.5)}.east .seat-info{order:2;flex-direction:column;gap:6px}.seat-info{display:flex;align-items:center;gap:8px}.seat-label{color:var(--cream);font-size:clamp(1rem,1.9vw,1.55rem);font-weight:700;line-height:1;white-space:nowrap;text-shadow:0 2px 4px rgba(0,0,0,.6);transition:color .2s ease}.seat-label.leader,.human-info p.leader{color:#ffd429;text-shadow:0 2px 4px rgba(0,0,0,.6),0 0 10px rgba(255,212,41,.5)}.point-heart{position:relative;display:grid;width:clamp(38px,3.6vw,54px);aspect-ratio:1;place-items:center;color:#fff;filter:drop-shadow(0 3px 0 rgba(0,0,0,.38));font-weight:800;flex-shrink:0}.point-heart:before,.point-heart:after{position:absolute;width:58%;height:82%;border:2px solid rgba(78,0,0,.5);border-radius:999px 999px 0 0;background:linear-gradient(#e82020,#a00000);content:""}.point-heart:before{left:17%;transform:rotate(-45deg);transform-origin:50% 78%}.point-heart:after{right:17%;transform:rotate(45deg);transform-origin:50% 78%}.point-heart span{position:relative;z-index:1;padding-top:5px;font-size:clamp(1rem,2.2vw,1.75rem);line-height:1;text-shadow:0 2px 0 rgba(0,0,0,.55)}.opponent-hand{--card-width: clamp(68px, 6.5vw, 108px);position:relative;width:calc(var(--card-width) + 24px);height:var(--card-height);flex-shrink:0}.opponent-hand .card{position:absolute;top:0;left:24px;transform:none;transform-origin:center center}.opponent-hand .card:nth-last-child(1){left:0;z-index:13}.opponent-hand .card:nth-last-child(2){left:2px;z-index:12}.opponent-hand .card:nth-last-child(3){left:4px;z-index:11}.opponent-hand .card:nth-last-child(4){left:6px;z-index:10}.opponent-hand .card:nth-last-child(5){left:8px;z-index:9}.opponent-hand .card:nth-last-child(6){left:10px;z-index:8}.opponent-hand .card:nth-last-child(7){left:12px;z-index:7}.opponent-hand .card:nth-last-child(8){left:14px;z-index:6}.opponent-hand .card:nth-last-child(9){left:16px;z-index:5}.opponent-hand .card:nth-last-child(10){left:18px;z-index:4}.opponent-hand .card:nth-last-child(11){left:20px;z-index:3}.opponent-hand .card:nth-last-child(12){left:22px;z-index:2}.opponent-hand .card:nth-last-child(13){left:24px;z-index:1}.north .opponent-hand .card{position:relative;top:auto;left:auto;flex:0 0 var(--card-width);transform:none;z-index:auto}.north .opponent-hand .card+.card{margin-left:calc(var(--card-width) * -.42)}.west .opponent-hand,.east .opponent-hand{--card-width: clamp(92px, 8vw, 138px);--card-height: calc(var(--card-width) * 1.55);display:flex;flex-direction:column;align-items:center;width:var(--card-height);height:auto;overflow:visible}.west .opponent-hand .card,.east .opponent-hand .card{position:relative;left:auto;top:auto;z-index:auto;flex:0 0 auto}.west .opponent-hand .card{transform:rotate(-90deg)}.east .opponent-hand .card{transform:rotate(90deg)}.west .opponent-hand .card+.card,.east .opponent-hand .card+.card{margin-top:calc(var(--card-height) * -.76)}.trick-zone{position:absolute;top:49%;left:50%;display:grid;width:min(640px,66vw);justify-items:center;gap:18px;transform:translate(-50%,-50%);z-index:20}.phase-passing .trick-zone{top:46%}.trick-table{--card-width: clamp(100px, 9vw, 138px);--card-height: calc(var(--card-width) * 1.55);position:relative;width:calc(var(--card-width) * 3.2);height:calc(var(--card-height) * 2.05)}.phase-passing .trick-table{display:none}.trick-card-slot{position:absolute;display:grid;width:var(--card-width);height:var(--card-height);place-items:center}.trick-card-slot>span{display:none}.trick-card-slot.north{top:0;left:50%;z-index:3;transform:translate(-50%)}.trick-card-slot.south{bottom:0;left:50%;z-index:4;transform:translate(-50%)}.trick-card-slot.west{top:50%;left:0;z-index:1;transform:translateY(-50%)}.trick-card-slot.east{top:50%;right:0;z-index:2;transform:translateY(-50%)}.trick-card-slot .card{box-shadow:0 10px 30px #00000059,0 2px 6px #0003;border-radius:10px}.trick-card-slot .card-face:hover{transform:none;box-shadow:0 10px 30px #00000059,0 2px 6px #0003}.trick-card-slot .card-face{transition:none}@keyframes play-from-south{0%{transform:translateY(42vh) scale(1.08);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes play-from-north{0%{transform:translateY(-38vh) scale(.55);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes play-from-west{0%{transform:translate(-42vw) scale(.55);opacity:0}to{transform:translate(0) scale(1);opacity:1}}@keyframes play-from-east{0%{transform:translate(42vw) scale(.55);opacity:0}to{transform:translate(0) scale(1);opacity:1}}.phase-playing .trick-card-slot.south .card{animation:play-from-south .42s cubic-bezier(.18,.85,.38,1) both}.phase-playing .trick-card-slot.north .card{animation:play-from-north .42s cubic-bezier(.18,.85,.38,1) both}.phase-playing .trick-card-slot.west .card{animation:play-from-west .42s cubic-bezier(.18,.85,.38,1) both}.phase-playing .trick-card-slot.east .card{animation:play-from-east .42s cubic-bezier(.18,.85,.38,1) both}@keyframes trick-take-north{0%,60%{transform:translate(0) scale(1);opacity:1}to{transform:translateY(-55vh) scale(.2);opacity:0}}@keyframes trick-take-south{0%,60%{transform:translate(0) scale(1);opacity:1}to{transform:translateY(48vh) scale(.2);opacity:0}}@keyframes trick-take-west{0%,60%{transform:translate(0) scale(1);opacity:1}to{transform:translate(-55vw) scale(.2);opacity:0}}@keyframes trick-take-east{0%,60%{transform:translate(0) scale(1);opacity:1}to{transform:translate(55vw) scale(.2);opacity:0}}.trick-completed[data-trick-winner=north] .trick-card-slot.north .card,.trick-completed[data-trick-winner=north] .trick-card-slot.south .card,.trick-completed[data-trick-winner=north] .trick-card-slot.west .card,.trick-completed[data-trick-winner=north] .trick-card-slot.east .card{animation:trick-take-north 1.35s cubic-bezier(.4,0,.7,.15) both}.trick-completed[data-trick-winner=south] .trick-card-slot.north .card,.trick-completed[data-trick-winner=south] .trick-card-slot.south .card,.trick-completed[data-trick-winner=south] .trick-card-slot.west .card,.trick-completed[data-trick-winner=south] .trick-card-slot.east .card{animation:trick-take-south 1.35s cubic-bezier(.4,0,.7,.15) both}.trick-completed[data-trick-winner=west] .trick-card-slot.north .card,.trick-completed[data-trick-winner=west] .trick-card-slot.south .card,.trick-completed[data-trick-winner=west] .trick-card-slot.west .card,.trick-completed[data-trick-winner=west] .trick-card-slot.east .card{animation:trick-take-west 1.35s cubic-bezier(.4,0,.7,.15) both}.trick-completed[data-trick-winner=east] .trick-card-slot.north .card,.trick-completed[data-trick-winner=east] .trick-card-slot.south .card,.trick-completed[data-trick-winner=east] .trick-card-slot.west .card,.trick-completed[data-trick-winner=east] .trick-card-slot.east .card{animation:trick-take-east 1.35s cubic-bezier(.4,0,.7,.15) both}.pass-panel{display:grid;width:100%;justify-items:center;gap:clamp(14px,2vw,24px);justify-content:center}.pass-header{display:flex;flex-direction:column;align-items:center;gap:6px}.pass-panel p{color:var(--cream);font-size:clamp(1.2rem,2.4vw,1.8rem);font-weight:700;line-height:1.2;text-align:center;text-shadow:0 2px 4px rgba(0,0,0,.5)}.pass-destination{display:flex;align-items:center;gap:10px}.pass-dir-arrow{font-size:clamp(2rem,4vw,3rem);line-height:1;animation:arrow-pulse 1.1s ease-in-out infinite}.pass-dest-name{color:var(--gold);font-size:clamp(1.1rem,2.2vw,1.65rem);font-weight:800;text-shadow:0 2px 4px rgba(0,0,0,.5)}@keyframes arrow-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.25);opacity:.75}}.pass-panel>span{display:none}.pass-slots{display:grid;grid-template-columns:repeat(3,minmax(120px,1fr));gap:clamp(18px,2.5vw,36px);width:min(700px,92%)}.pass-slots div{display:grid;aspect-ratio:.72;place-items:center;border:3px solid rgba(255,255,255,.5);border-radius:18px;color:#ffffff6b;background:#0000001f;box-shadow:inset 0 0 12px #0000002e,0 6px 16px #0003;font-size:clamp(4.5rem,8.5vw,7.5rem);font-weight:800;line-height:1}.pass-slots div.filled{border-color:#ffffffd9;background:transparent;padding:0;overflow:hidden}.pass-slots div.filled .card{width:100%;height:100%;border-radius:16px;animation:slot-flip-in .35s cubic-bezier(.34,1.56,.64,1) both}@keyframes slot-flip-in{0%{transform:rotateY(-90deg) scale(.6);opacity:0}to{transform:rotateY(0) scale(1);opacity:1}}@keyframes fly-to-north{0%{transform:translate(0) scale(1);opacity:1}70%{opacity:.9}to{transform:translateY(-52vh) scale(.22);opacity:0}}@keyframes fly-to-west{0%{transform:translate(0) scale(1);opacity:1}70%{opacity:.9}to{transform:translate(-54vw,-6vh) scale(.22);opacity:0}}@keyframes fly-to-east{0%{transform:translate(0) scale(1);opacity:1}70%{opacity:.9}to{transform:translate(54vw,-6vh) scale(.22);opacity:0}}.passing-out-across .pass-slots div.filled{animation:fly-to-north .54s cubic-bezier(.3,0,.7,.1) forwards}.passing-out-left .pass-slots div.filled{animation:fly-to-west .54s cubic-bezier(.3,0,.7,.1) forwards}.passing-out-right .pass-slots div.filled{animation:fly-to-east .54s cubic-bezier(.3,0,.7,.1) forwards}.passing-out-across .pass-slots div.filled:nth-child(2),.passing-out-left .pass-slots div.filled:nth-child(2),.passing-out-right .pass-slots div.filled:nth-child(2){animation-delay:70ms}.passing-out-across .pass-slots div.filled:nth-child(3),.passing-out-left .pass-slots div.filled:nth-child(3),.passing-out-right .pass-slots div.filled:nth-child(3){animation-delay:.14s}.passing-out-across .pass-arrow,.passing-out-left .pass-arrow,.passing-out-right .pass-arrow{pointer-events:none;opacity:.35;transition:opacity .12s ease}.passing-out-across .pass-header,.passing-out-left .pass-header,.passing-out-right .pass-header{opacity:0;transition:opacity .2s ease}.pass-arrow{display:grid;width:min(260px,100%);height:66px;place-items:center;border-radius:10px;border:2px solid rgba(255,255,255,.15);color:#fff;background:var(--felt-deep);box-shadow:0 5px #0006;cursor:pointer;font-size:clamp(1.4rem,2.6vw,2rem);font-weight:800;line-height:1;letter-spacing:.05em;text-transform:uppercase}.pass-arrow:disabled{cursor:not-allowed;opacity:.5}.human-seat{--card-width: clamp(112px, 9vw, 156px);--card-height: calc(var(--card-width) * 1.55);position:absolute;right:0;bottom:calc(var(--card-height) * -.5 + 6px);left:0;display:grid;justify-items:center;gap:10px;z-index:5}.human-info{display:grid;grid-template-columns:auto auto;align-items:center;justify-self:center;padding-left:0;gap:10px;margin-bottom:2px}.human-info p{color:var(--cream);font-size:clamp(1.1rem,2.2vw,1.65rem);font-weight:700;line-height:1;text-shadow:0 2px 4px rgba(0,0,0,.6);transition:color .2s ease}.hand-row{--card-width: clamp(112px, 9vw, 156px);--card-height: calc(var(--card-width) * 1.55);display:flex;width:min(1180px,88vw);min-height:var(--card-height);justify-content:center;overflow:visible}.hand-card{flex:0 0 var(--card-width);transition:transform .14s ease}.hand-card+.hand-card{margin-left:calc(var(--card-width) * -.42)}.hand-card.playable{transform:translateY(-10px)}.hand-card.selected-pass{transform:translateY(-18px)}.phase-passing .hand-card.selected-pass .card{filter:brightness(.55) saturate(.6);transition:filter .18s ease}.phase-playing .hand-card:not(.playable) .card-face{filter:saturate(.45) brightness(.72)}.hearts-board.dealing .hand-card .card,.hearts-board.dealing .opponent-hand .card{animation:deal-around .76s cubic-bezier(.18,.8,.22,1) backwards}.hearts-board.dealing .hand-card:nth-child(2n) .card,.hearts-board.dealing .opponent-hand .card:nth-child(2n){animation-delay:45ms}.hearts-board.dealing .hand-card:nth-child(3n) .card,.hearts-board.dealing .opponent-hand .card:nth-child(3n){animation-delay:90ms}@keyframes deal-around{0%{opacity:0;transform:translate(var(--deal-x, 0),var(--deal-y, 0)) rotate(-18deg) scale(.72)}62%{opacity:1}to{opacity:1}}.north .card{--deal-y: 180px}.west .card{--deal-x: 200px}.east .card{--deal-x: -200px}.human-seat .card{--deal-y: -200px}@media(max-width:900px){.opponent-hand{--card-width: clamp(52px, 6vw, 80px)}.west .opponent-hand,.east .opponent-hand{--card-width: clamp(76px, 7vw, 112px);--card-height: calc(var(--card-width) * 1.55);width:var(--card-height)}.trick-zone{width:min(500px,72vw)}.trick-table{--card-width: clamp(82px, 9vw, 114px);--card-height: calc(var(--card-width) * 1.55)}.pass-slots{grid-template-columns:repeat(3,minmax(90px,1fr))}.human-seat{--card-width: clamp(86px, 10vw, 122px);--card-height: calc(var(--card-width) * 1.55);bottom:calc(var(--card-height) * -.5 + 6px)}.hand-row{--card-width: clamp(86px, 10vw, 122px);--card-height: calc(var(--card-width) * 1.55);width:90vw;transform:none}}@media(max-width:620px){.opponent-hand{--card-width: 44px}.north .opponent-hand{--card-width: clamp(44px, 11vw, 62px);--card-height: calc(var(--card-width) * 1.55);margin-top:calc(var(--card-height) * -.5)}.opponent-seat.west{top:14%;transform:none;flex-direction:column;align-items:flex-start;gap:4px}.opponent-seat.east{top:14%;transform:none;flex-direction:column;align-items:flex-end;gap:4px}.west .seat-info,.east .seat-info{order:1;flex-direction:row;gap:4px;padding-left:4px}.east .seat-info{padding-left:0;padding-right:4px;flex-direction:row-reverse}.west .opponent-hand,.east .opponent-hand{order:2;--card-width: clamp(54px, 13vw, 72px);--card-height: calc(var(--card-width) * 1.55);width:var(--card-height)}.west .seat-label,.east .seat-label{font-size:clamp(1rem,4vw,1.2rem)}.west .point-heart,.east .point-heart{width:clamp(34px,8vw,44px)}.trick-zone{top:44%;width:88vw}.pass-panel p{font-size:clamp(.95rem,4vw,1.2rem)}.pass-dest-name{font-size:clamp(.9rem,4vw,1.1rem)}.pass-dir-arrow{font-size:clamp(1.2rem,5vw,1.8rem)}.trick-table{--card-width: clamp(72px, 17vw, 96px);--card-height: calc(var(--card-width) * 1.55)}.pass-slots{grid-template-columns:repeat(3,minmax(56px,1fr));gap:8px}.pass-slots div{font-size:clamp(2.2rem,8vw,3.5rem);border-radius:12px;border-width:2px}.pass-arrow{height:48px;font-size:1.1rem}.human-seat{--card-width: clamp(50px, 13vw, 62px);--card-height: calc(var(--card-width) * 1.55);bottom:0;padding-bottom:max(8px,env(safe-area-inset-bottom));gap:6px}.hand-row{--card-width: clamp(50px, 13vw, 62px);--card-height: calc(var(--card-width) * 1.55);width:100%;flex-wrap:wrap;justify-content:center;gap:5px;overflow:visible;padding-inline:8px;transform:none}.hand-card{flex:0 0 var(--card-width)}.hand-card+.hand-card{margin-left:0}.hand-card.playable{transform:translateY(-6px)}.hand-card.selected-pass{transform:translateY(-10px)}}.game-controls{position:fixed;top:18px;right:18px;z-index:12}.game-actions{display:flex;gap:9px}.control-button{display:inline-flex;min-height:48px;align-items:center;justify-content:center;gap:8px;border-radius:10px;padding:0 14px;color:var(--cream);background:linear-gradient(#444,#050505 54%);box-shadow:inset 0 0 0 2px #ffffff26,0 5px #00000059;cursor:pointer;font-weight:850}.control-button:active{transform:translateY(1px)}@media(max-width:720px){.game-controls{top:10px;right:10px}.settings-button,.scoreboard-button{width:46px;padding:0}.control-label{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}}.pause-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:20px;background:#04100a80;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:30}.pause-modal{width:min(420px,100%);border:1px solid rgba(255,255,255,.22);border-radius:8px;padding:clamp(26px,6vw,46px);text-align:center;color:var(--cream);background:radial-gradient(circle at 50% 0%,rgba(255,255,255,.16),transparent 42%),linear-gradient(145deg,var(--modal-start),var(--modal-end));box-shadow:0 30px 90px #0000006b}.pause-modal p{color:var(--muted);font-size:.75rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.pause-modal h2{margin-top:6px;font-size:clamp(2.8rem,11vw,5rem);line-height:.95}.pause-modal button{display:inline-flex;min-height:50px;align-items:center;justify-content:center;gap:9px;margin-top:26px;border-radius:8px;padding:0 28px;cursor:pointer;color:var(--accent-contrast);background:var(--gold);box-shadow:0 4px 0 var(--gold-deep);font-weight:950}.scoreboard-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:center;padding:18px;background:#00000094;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.scoreboard-modal{display:grid;width:min(900px,96vw);min-height:min(680px,88dvh);grid-template-rows:auto minmax(0,1fr) auto auto;overflow:hidden;border:4px solid rgba(255,255,255,.9);border-radius:18px;color:#fff;background:linear-gradient(#070707,#222 74%,#2f2f2f);box-shadow:inset 0 0 0 3px #000c,0 24px 70px #00000080}.scoreboard-top{display:grid;min-height:82px;place-items:center;border-bottom:3px solid rgba(255,255,255,.72);background:linear-gradient(#3d3d3d,#2f2f2f)}.scoreboard-top h2{color:#fff;font-size:clamp(2.8rem,7vw,5rem);line-height:1;text-shadow:0 5px 0 #000000,0 0 12px #000000}.scoreboard-table-wrap{overflow:auto;padding:28px clamp(14px,3vw,42px)}.scoreboard-table{width:100%;border-collapse:collapse;table-layout:fixed;font-size:clamp(1rem,2vw,1.55rem)}.scoreboard-table th,.scoreboard-table td{border-top:3px solid rgba(255,255,255,.78);border-right:3px solid rgba(255,255,255,.68);padding:12px 10px;text-align:center}.scoreboard-table th:last-child,.scoreboard-table td:last-child{border-right:0}.scoreboard-table tbody tr:last-child th,.scoreboard-table tbody tr:last-child td{border-bottom:3px solid rgba(255,255,255,.78)}.scoreboard-table th{color:#fff;font-weight:950}.scoreboard-table .you-column{color:#ffd429}.scoreboard-table td{font-weight:950}.scoreboard-table td span,.scoreboard-table td strong{display:inline-flex;width:48%;justify-content:center}.scoreboard-table td span{border-right:2px dotted rgba(255,255,255,.34);color:#fff}.scoreboard-table td strong{color:inherit}.scoreboard-empty{padding:28px 0;color:#ffffff8c;text-align:center;font-size:1rem}.scoreboard-note{padding:0 24px 12px;color:#ffffffc7;text-align:center;font-weight:850}.scoreboard-actions{display:flex;justify-content:center;gap:14px;padding:20px}.scoreboard-actions button{min-width:170px;min-height:58px;border-radius:10px;color:#fff;background:linear-gradient(#3b3b3b,#050505 46%);box-shadow:inset 0 0 0 3px #ffffff1f,0 5px #000000a6;cursor:pointer;font-size:clamp(1.15rem,2.4vw,2rem);font-weight:950;text-transform:uppercase}.scoreboard-actions .scoreboard-primary{color:#fff}@media(max-width:620px){.scoreboard-backdrop{padding:10px;align-items:flex-end}.scoreboard-modal{width:100%;min-height:72dvh;max-height:92dvh;border-radius:18px 18px 12px 12px;border-width:3px;grid-template-rows:auto minmax(0,1fr) auto auto}.scoreboard-top{min-height:56px}.scoreboard-top h2{font-size:clamp(1.6rem,6vw,2.4rem)}.scoreboard-table-wrap{padding:14px 8px;overflow-x:auto}.scoreboard-table{font-size:clamp(.72rem,2.8vw,1rem);table-layout:fixed}.scoreboard-table th,.scoreboard-table td{padding:8px 3px;border-width:2px}.scoreboard-table td span,.scoreboard-table td strong{width:48%;font-size:.95em}.scoreboard-note{padding:0 12px 8px;font-size:.8rem}.scoreboard-actions{flex-direction:column-reverse;gap:8px;padding:12px}.scoreboard-actions button{width:100%;min-height:50px;font-size:clamp(1rem,4vw,1.3rem)}}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:20px;background:#04100aa6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100}.settings-modal{width:min(380px,100%);border:1px solid rgba(255,255,255,.18);border-radius:14px;padding:20px 24px 24px;color:var(--cream);background:linear-gradient(145deg,var(--modal-start),var(--modal-end));box-shadow:0 24px 70px #00000073}.settings-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.settings-heading p{display:none}.settings-heading h2{font-size:1.25rem;font-weight:800;line-height:1;letter-spacing:.02em}.settings-close{display:inline-flex;width:34px;min-height:34px;align-items:center;justify-content:center;border-radius:8px;cursor:pointer;color:var(--cream);background:#ffffff1f;box-shadow:inset 0 0 0 1px #ffffff26;flex-shrink:0}.settings-close:hover{background:#fff3}.settings-menu{display:grid;gap:8px}.settings-menu button,.settings-theme-panel button,.settings-back{display:inline-flex;width:100%;min-height:42px;align-items:center;justify-content:flex-start;gap:10px;padding:0 14px;border-radius:8px;cursor:pointer;color:var(--cream);background:#ffffff1a;box-shadow:inset 0 0 0 1px #ffffff24;font-size:.95rem;font-weight:700}.settings-menu button:hover,.settings-theme-panel button:hover,.settings-back:hover{background:#ffffff2e}.rules-panel{margin-top:4px}.rules-panel ul{display:grid;gap:8px;padding-left:18px;color:#ffffffc7;font-size:.875rem;line-height:1.45;margin-bottom:16px}.settings-back{width:auto;padding:0 14px}.settings-theme-panel{display:grid;gap:8px}.settings-theme-panel button.active{outline:2px solid var(--gold);outline-offset:2px;background:#ffffff2e}
