:root{color-scheme:light;font-family:Inter,system-ui,sans-serif;background:#f5f7fb;color:#1f2937}*{box-sizing:border-box}body{margin:0}.app-shell{max-width:1200px;margin:8px auto 0;padding:clamp(8px,3vw,12px)}header{margin-bottom:16px;text-align:center}header h1{margin:0 0 4px;font-size:2rem}header p{margin:0 0 24px;color:#4b5563}.game-info{margin-bottom:16px;text-align:center}.game-info-title{margin:0 0 8px}.game-info-desc{margin:0;color:#4b5563}.error{margin-bottom:24px;padding:14px 16px;border-radius:10px;background:#fee2e2;color:#991b1b}.grid-layout{display:grid;gap:24px;grid-template-columns:280px 280px minmax(320px,1fr)}.panel{background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:18px}.panel h2{margin-top:0;font-size:1.1rem}button{padding:clamp(6px,1.5vw,8px) clamp(10px,2vw,12px);font-size:clamp(.75rem,1.5vw,.85rem);border:none;border-radius:8px;background:#2563eb;color:#fff;cursor:pointer;font-weight:600;display:inline-flex;align-items:center;justify-content:center;line-height:1}button:disabled{opacity:.5;cursor:not-allowed}button:active{transform:scale(.96);box-shadow:inset 0 3px 5px #00000020;filter:brightness(.9)}button:disabled:active{transform:none;box-shadow:none;filter:none}.filter-list{display:flex;justify-content:center;gap:8px;margin-bottom:4px}.filter-list .example-select{max-width:200px}.toolbar{display:flex;gap:12px;align-items:center;justify-content:center;flex-wrap:wrap;margin-bottom:24px;max-width:750px;margin-left:auto;margin-right:auto}.toolbar button{display:inline-flex;align-items:center;gap:8px;padding:clamp(6px,1.5vw,8px) clamp(10px,2vw,12px);font-family:inherit;font-size:clamp(.75rem,1.5vw,.85rem)}.file-label{border:none;border-radius:8px;background:#2563eb;color:#fff;cursor:pointer;font-weight:600}.file-label,.example-select{display:inline-flex;align-items:center;gap:8px;padding:clamp(6px,1.5vw,8px) clamp(10px,2vw,12px);font-family:inherit;font-size:clamp(.75rem,1.5vw,.85rem)}.example-select{background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;color:inherit;max-width:150px}.file-label input{display:none}.item-list{list-style:none;margin:0;padding:0}.item-list li{padding:10px 12px;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:10px;cursor:pointer;transition:background .2s ease}.item-list li:hover{background:#eff6ff}.item-list li.selected{background:#2563eb;color:#fff;border-color:#1d4ed8}.timeline-list{list-style:none;margin:0;padding:0;max-height:320px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:14px;background:#fff}.timeline-item{padding:10px 12px;border-bottom:1px solid #e5e7eb;cursor:pointer;transition:background .2s ease}.timeline-item:hover{background:#f3f4f6}.timeline-item.selected{background:#2563eb;color:#fff}.timeline-item.has-note{font-weight:700}.timeline-item:last-child{border-bottom:none}.status-card-container{width:100%;margin-bottom:24px}.status-card{background:#f8fafc;border:1px solid #e5e7eb;border-radius:clamp(12px,2vw,15px);padding:clamp(12px,2.5vw,15px);width:100%;max-width:750px;margin:0 auto;box-sizing:border-box;position:relative}.share-button{position:absolute;right:3%;bottom:clamp(80px,15vw,90px)}.note-container{display:flex;justify-content:flex-start;margin-top:-8px;margin-bottom:8px;padding-right:clamp(8px,2vw,16px)}.note-content{background:transparent;border:1px solid #cbd5e1;border-radius:8px;padding:8px 12px;font-size:clamp(.8rem,2vw,.9rem);color:#4b5563;max-width:60%;white-space:pre-wrap;text-align:left}.note-label{font-weight:600;margin-bottom:4px;font-size:.8em;text-transform:uppercase;letter-spacing:.05em}.note-box{min-height:80px;padding:14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;white-space:pre-wrap}.note-section textarea{width:100%;min-height:120px;padding:14px;border:1px solid #d1d5db;border-radius:14px;font-family:inherit;resize:vertical}.note-section button{margin-top:12px}.scrubber-container{padding-top:14px;border-top:1px solid #e5e7eb;margin-top:clamp(10px,3vw,14px);display:flex;align-items:center;gap:clamp(6px,2vw,9px)}.scrubber-wrapper{flex:1;position:relative;display:flex;align-items:center}.scrubber{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;background:#e5e7eb;border-radius:4px;outline:none;transition:background .2s}.scrubber:disabled{opacity:.5;cursor:not-allowed}.scrubber::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#2563eb;cursor:pointer;border:2px solid white;box-shadow:0 1px 3px #0000004d;transition:transform .1s}.scrubber::-webkit-slider-thumb:hover{transform:scale(1.1)}.scrubber::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#2563eb;cursor:pointer;border:2px solid white;box-shadow:0 1px 3px #0000004d;transition:transform .1s}.scrubber::-moz-range-thumb:hover{transform:scale(1.1)}.scrubber-callout{position:absolute;bottom:100%;margin-bottom:12px;transform:translate(-50%);background:#1f2937;color:#f9fafb;padding:4px 8px;border-radius:6px;font-size:.75rem;font-weight:600;white-space:nowrap;pointer-events:none;box-shadow:0 4px 6px #0000001a;z-index:10}.scrubber-callout:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-width:5px;border-style:solid;border-color:#1f2937 transparent transparent transparent}.playback-controls-wrapper{margin-top:clamp(8px,2.5vw,12px)}.step-controls{display:flex;gap:clamp(4px,1vw,6px);flex-wrap:wrap}.step-controls button{min-width:50px;min-height:25px}.top-bar{display:grid;grid-template-columns:1fr 1fr 1fr;align-items:flex-start;gap:clamp(8px,1.5vw,10px);width:100%;z-index:10;height:0px}.top-bar h2{margin:0;font-size:1.1rem}.status-subtitle{color:#6b7280;font-size:.95rem}.team-score-section{display:flex;flex-direction:column;align-items:center;min-width:clamp(80px,10vw,100px)}.team-score-section-ew{justify-self:start}.team-score-section-ns{justify-self:end}.team-name-ew{font-weight:700;font-size:clamp(.85rem,6vw,1.5rem);color:#4b5563;white-space:nowrap}.team-name-ns{font-weight:700;font-size:clamp(.65rem,6vw,1.5rem);color:#4b5563;white-space:nowrap}.team-score-value{font-size:clamp(1.5rem,10vw,3.5rem);font-weight:700;line-height:1.2}@keyframes scoreIncrease{0%{transform:scale(1);color:inherit}20%{transform:scale(1.4);color:#10b981}80%{transform:scale(1.4);color:#10b981}to{transform:scale(1);color:inherit}}.score-increase-anim{animation:scoreIncrease 1s ease-in-out;display:inline-block}.trump-icon-section{display:flex;align-items:flex-start;justify-self:center;font-size:clamp(3rem,8vw,4.5rem);gap:12px;min-width:80px;justify-content:center;line-height:1;margin-top:-5px}.trump-maker-arrow{font-size:1.1em;align-self:center}.trump-icon-transparent{color:transparent}.trick-boxes-container{display:flex;flex-direction:column;align-items:center;margin-top:4px}.trick-boxes-row{display:flex;gap:4px;font-size:.6em;padding:4px 8px 4px 4px}.trick-boxes-row-full{display:flex;gap:4px;width:100%;justify-content:center;font-size:.6em;padding:4px 8px 4px 4px}.trick-box-won{width:clamp(16px,2.5vw,24px);height:clamp(16px,2.5vw,24px);display:flex;align-items:center;justify-content:center;background-color:#10b981;color:#fff;border-radius:4px;font-size:10px}.trick-box-empty{width:clamp(16px,2.5vw,24px);height:clamp(16px,2.5vw,24px);border:1px solid #d1d5db;border-radius:4px}.trick-box-lost{width:clamp(16px,2.5vw,24px);height:clamp(16px,2.5vw,24px);display:flex;align-items:center;justify-content:center;background-color:#ef4444;color:#fff;border-radius:4px;font-size:10px}.empty-trick-box-ew{height:42px}.empty-trick-box-ns{height:22px}.table-map{position:relative;display:grid;grid-template-columns:1fr 1fr 1fr;align-items:center;justify-items:center;gap:clamp(8px,2vw,10px);width:100%;max-width:100%;margin:clamp(4em,10vw,6em) auto 2em;min-height:clamp(350px,45vw,380px)}.seat{width:clamp(55px,15vw,68px);height:clamp(38px,8vw,44px);border-radius:16px;display:flex;align-items:center;justify-content:center;text-align:center;padding:clamp(2px,1vw,4px);background:#eff6ff;border:1px solid #dbeafe;font-size:clamp(.55rem,1.5vw,.68rem);color:#1f2937;position:relative;word-break:break-word;z-index:1}.seat>div:first-child{flex:1}.seat-label{font-size:clamp(.7rem,2vw,.9rem);font-weight:700}.player-name{font-weight:500;font-size:clamp(.7rem,2.5vw,1.1rem);margin-top:4px;text-align:center}.bid-label{position:absolute;font-size:clamp(.8rem,1.2vw,1rem);font-weight:700;background:#059669;color:#fff;padding:2px 6px;border-radius:4px;white-space:nowrap;bottom:-16px;z-index:1}.dealer-badge{position:absolute;top:-6px;right:-6px;width:clamp(24px,3.5vw,30px);height:clamp(24px,3.5vw,30px);background:#f59e0b;color:#fff;border-radius:50%;font-size:clamp(.7rem,1.2vw,.8rem);font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid white;box-shadow:0 1px 2px #00000026;z-index:2}.winner-badge{position:absolute;top:-6px;left:-6px;width:clamp(24px,3.5vw,30px);height:clamp(24px,3.5vw,30px);background:#b2fcb2;color:#000;border-radius:50%;font-size:clamp(.7rem,1.2vw,.8rem);font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid white;box-shadow:0 1px 2px #00000026;z-index:2}.seat-container{position:relative;display:flex;justify-content:center;align-items:center;padding:clamp(5px,1vw,8px);border:1px solid black;border-radius:8px;width:100%}.seat-container.winner{border-color:#10b981;background:#d1fae5}.seat-container.selected{border-color:#1d4ed8}.seat-container.inactive-seat{opacity:.5;filter:grayscale(.5);position:relative;overflow:hidden}.seat-container.inactive-seat:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to top left,transparent 48%,rgba(38,38,38,.8) 48%,rgba(38,38,38,.8) 52%,transparent 52%),linear-gradient(to top right,transparent 48%,rgba(38,38,38,.8) 48%,rgba(38,38,38,.8) 52%,transparent 52%);pointer-events:none;z-index:5}.seat-container-n{grid-column:2;grid-row:1;align-self:start;flex-direction:column}.seat-container-e{grid-column:3;grid-row:2;justify-self:end;flex-direction:column}.seat-container-s{grid-column:2;grid-row:3;align-self:end;flex-direction:column}.seat-container-w{grid-column:1;grid-row:2;justify-self:start;flex-direction:column}.trick-center{grid-column:2;grid-row:2;display:grid;grid-template-columns:clamp(30px,8vw,42px) clamp(30px,8vw,42px) clamp(30px,8vw,42px);grid-template-rows:clamp(42px,11vw,55px) clamp(42px,11vw,55px) clamp(42px,11vw,55px);gap:clamp(1px,.2vw,2px);justify-content:center;align-content:center}.played-card{width:clamp(28px,7vw,42px);height:clamp(40px,10vw,60px);background:#fff;border:1px solid #d1d5db;border-radius:clamp(4px,1vw,6px);display:flex;align-items:center;justify-content:center;font-size:clamp(.9rem,2.5vw,1.1rem);font-weight:700;box-shadow:0 2px 4px #0000001a}.played-card.trump-card,.discard-card.trump-card,.kitty-card.trump-card,.turned-down-upcard.trump-card,.picked-upcard.trump-card{background:#fcf3ad;border-color:#f8d034}.played-card.winning-card{border:3px solid #10b981}.upcard{grid-column:2;grid-row:2;transition:transform .3s ease}@keyframes slideInN{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideInE{0%{transform:translate(50px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInS{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideInW{0%{transform:translate(-50px);opacity:0}to{transform:translate(0);opacity:1}}.card-n{grid-column:2;grid-row:1;animation:slideInN .25s ease-out forwards}.card-e{grid-column:3;grid-row:2;animation:slideInE .25s ease-out forwards}.card-s{grid-column:2;grid-row:3;animation:slideInS .25s ease-out forwards}.card-w{grid-column:1;grid-row:2;animation:slideInW .25s ease-out forwards}.hand-container{width:100%;display:flex;justify-content:left;padding-left:2px;z-index:0}.left-hand{right:100%;margin-right:clamp(2px,1vw,4px)}.right-hand{left:100%;margin-left:clamp(2px,1vw,4px)}.player-hand{font-size:clamp(.85rem,2.5vw,1rem);font-weight:700;text-align:left;margin-top:clamp(2px,.5vw,3px);padding:clamp(2px,.5vw,3px);border-radius:4px;line-height:1.2}.inactive-hand{position:absolute;top:43%;left:45%;font-size:clamp(2rem,10vw,3rem);opacity:50%}.card-in-hand{color:#1f2937}.card-in-hand.trump{color:#edbe00}.suit-icon-black{color:#1f2937;width:.9em;display:inline-block}.suit-icon-red{color:#dc2626;width:.9em;display:inline-block}.details-panel{display:flex;flex-direction:column;gap:24px}.details-row{display:flex;align-items:center;justify-content:space-between;gap:clamp(8px,2vw,10px);flex-wrap:wrap}.current-trick{padding:16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;min-height:56px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.kitty-discard-box{position:absolute;left:3%;bottom:clamp(80px,15vw,90px);display:flex;flex-direction:column;justify-content:center;gap:clamp(4px,1.5vw,8px);padding:clamp(6px,2vw,12px);background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px}.kitty-section,.discard-section{display:flex;flex-direction:column;align-items:center;gap:4px}.kitty-label,.discard-label{font-size:clamp(10.5px,2.5vw,12px);font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.kitty-cards,.discard-card-container{display:flex;gap:clamp(1px,1vw,2px)}.kitty-cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(3px,2vw,6px)}.kitty-and-discard-cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(2px,1.5vw,4px)}.out-of-play-cards-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(1px,1vw,2px)}.kitty-card,.discard-card,.turned-down-upcard,.picked-upcard{background:#fff;width:clamp(25px,8vw,31.5px);height:clamp(35px,10vw,42px);font-size:clamp(.7rem,2.5vw,.9rem);opacity:75%}.small-card{width:clamp(15px,3.5vw,20px);height:clamp(25px,5vw,27px);font-size:clamp(.5rem,1.5vw,.6rem)}.middle-card{width:clamp(17px,3.5vw,25px);height:clamp(28px,5vw,34px);font-size:clamp(.6rem,1.5vw,.7rem)}.unknown-card{background:#f1f5f9;color:#94a3b8;font-size:1.5rem}.turned-down-upcard,.discard-card{position:relative}.turned-down-upcard:after,.discard-card:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to top left,transparent 46%,rgba(38,38,38,.3) 46%,rgba(38,38,38,.3) 54%,transparent 54%);pointer-events:none;z-index:1}
