:root{--bg-body: #f5f7fb;--bg-surface: #ffffff;--bg-error: #fee2e2;--bg-surface-hover: #eff6ff;--bg-medium: #e9eef6;--bg-surface-alt: #f8fafc;--bg-bid: #059669;--bg-dealer: #f59e0b;--bg-winner: #d1fae5;--bg-trump-card: #fcf3ad;--bg-unknown-card: #f1f5f9;--bg-trick-won: lightgreen;--bg-trick-lost: lightpink;--bg-kitty-discard: #f5f7fb;--color-primary: #2563eb;--color-success: #10b981;--color-danger: #ef4444;--color-red-suit: #dc2626;--color-black-suit: #1f2937;--text-primary: #1f2937;--text-primary-fade: rgba(31, 41, 55, .6);--text-secondary: #4b5563;--text-error: #991b1b;--text-inverse-alt: #f9fafb;--text-muted: #6b7280;--text-unknown-card: #94a3b8;--text-trump-hand: #e9c11d;--text-light: #ffffff;--border-primary: #1d4ed8;--border-seat: #dbeafe;--border-light: #e5e7eb;--border-medium: #d1d5db;--border-dark: #1f2937;--border-trump-card: #f8d034}[data-theme=dark]{--bg-body: #0f172a;--bg-surface: #1e293b;--bg-error: #7f1d1d;--bg-surface-hover: #334155;--bg-medium: #334155;--bg-surface-alt: #0f172a;--bg-bid: #059669;--bg-dealer: #d97706;--bg-winner: #064e3b;--bg-trump-card: #805717;--bg-unknown-card: #0f172a;--bg-card: #1e293b;--bg-trick-won: #064e3b;--bg-trick-lost: #b96666;--bg-kitty-discard: #0f172a;--color-primary: #3b82f6;--color-success: #10b981;--color-danger: #ef4444;--color-red-suit: #fc0909;--color-black-suit: #f8fafc;--text-primary: #f1f5f9;--text-primary-fade: rgba(241, 245, 249, .6);--text-secondary: #cbd5e1;--text-error: #fca5a5;--text-inverse-alt: #0f172a;--text-muted: #94a3b8;--text-unknown-card: #64748b;--text-trump-hand: #fbbf24;--text-light: #ffffff;--border-primary: #3b82f6;--border-seat: #475569;--border-light: #334155;--border-medium: rgba(148, 163, 184, 1);--border-dark: #475569;--border-trump-card: #fbbf24}:root{color-scheme:light;font-family:Inter,system-ui,sans-serif;background:var(--bg-body);color:var(--text-primary)}*{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:var(--text-secondary)}.game-info{margin-bottom:16px;text-align:center}.game-info-title{margin:0 0 8px}.game-info-desc{margin:0;color:var(--text-secondary)}.error{margin-bottom:24px;padding:14px 16px;border-radius:10px;background:var(--bg-error);color:var(--text-error)}.grid-layout{display:grid;gap:24px;grid-template-columns:280px 280px minmax(320px,1fr)}.panel{background:var(--bg-body);border:1px solid var(--border-medium);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:var(--color-primary);color:var(--text-light);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:8px}.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:var(--color-primary);color:var(--text-light);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:var(--bg-body);border:1px solid var(--border-medium);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 var(--border-medium);border-radius:12px;margin-bottom:10px;cursor:pointer;transition:background .2s ease}.item-list li:hover{background:var(--bg-body)}.item-list li.selected{background:var(--color-primary);color:var(--text-light);border-color:var(--border-primary)}.timeline-list{list-style:none;margin:0;padding:0;max-height:320px;overflow-y:auto;border:1px solid var(--border-medium);border-radius:14px;background:var(--bg-body)}.timeline-item{padding:10px 12px;border-bottom:1px solid var(--border-medium);cursor:pointer;transition:background .2s ease}.timeline-item:hover{background:var(--bg-body)}.timeline-item.selected{background:var(--color-primary);color:var(--text-light)}.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:var(--bg-body);border:1px solid var(--border-medium);border-radius:clamp(12px,2vw,15px);padding:clamp(12px,2.5vw,15px) clamp(6px,2vw,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 var(--border-medium);border-radius:8px;padding:8px 12px;font-size:clamp(.8rem,2vw,.9rem);color:var(--text-secondary);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:var(--bg-body);border:1px solid var(--border-medium);border-radius:14px;white-space:pre-wrap}.note-section textarea{width:100%;min-height:120px;padding:14px;border:1px solid var(--border-medium);border-radius:14px;font-family:inherit;resize:vertical}.note-section button{margin-top:12px}.scrubber-container{padding-top:14px;border-top:1px solid var(--border-medium);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:var(--border-medium);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:var(--color-primary);cursor:pointer;border:2px solid var(--bg-body);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:var(--color-primary);cursor:pointer;border:2px solid var(--bg-body);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:var(--text-primary);color:var(--text-light);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:var(--text-primary) 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;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:var(--text-muted);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:var(--text-secondary);white-space:nowrap}.team-name-ns{font-weight:700;font-size:clamp(.65rem,6vw,1.5rem);color:var(--text-secondary);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:var(--color-success)}80%{transform:scale(1.4);color:var(--color-success)}to{transform:scale(1);color:inherit}}.score-increase-anim{animation:scoreIncrease 1s ease-in-out;display:inline-block}.trump-icon-section{position:absolute;color:var(--text-secondary);display:flex;align-items:flex-start;justify-self:center;font-size:clamp(3rem,8vw,5rem);gap:12px;min-width:80px;justify-content:center;line-height:1}.trump-icon-section.ew-maker{left:19%}.trump-icon-section.ns-maker{right:19%}.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:var(--color-success);color:var(--text-light);border-radius:4px;font-size:10px}.trick-box-empty{width:clamp(16px,2.5vw,24px);height:clamp(16px,2.5vw,24px);border:1px solid var(--border-medium);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:var(--color-danger);color:var(--text-light);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:var(--bg-body);border:1px solid var(--border-medium);font-size:clamp(.55rem,1.5vw,.68rem);color:var(--text-primary);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:var(--bg-bid);color:var(--text-light);padding:2px 6px;border-radius:4px;white-space:nowrap;bottom:-18px;z-index:1}.dealer-badge{position:absolute;top:-6px;right:-6px;width:clamp(24px,3.5vw,30px);height:clamp(24px,3.5vw,30px);background:var(--bg-dealer);color:var(--text-light);border-radius:50%;font-size:clamp(.8rem,3vw,1rem);font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-body);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:var(--bg-winner);color:var(--text-primary);border-radius:50%;font-size:clamp(.7rem,1.2vw,.8rem);font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-body);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);background:var(--bg-medium);border:1px solid var(--border-dark);border-radius:8px;width:100%}.seat-container.winner{border-color:var(--color-success);background:var(--bg-winner)}.seat-container.selected{border-color:var(--color-primary)}.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%,var(--text-primary-fade) 48%,var(--text-primary-fade) 52%,transparent 52%),linear-gradient(to top right,transparent 48%,var(--text-primary-fade) 48%,var(--text-primary-fade) 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:var(--bg-card);border:1px solid var(--border-dark);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:var(--bg-trump-card);border-color:var(--border-trump-card)}.played-card.winning-card{border:3px solid var(--color-success)}.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}@keyframes slamInN{0%{transform:translateY(-100px) scale(3);opacity:0}60%{transform:translateY(0) scale(1);opacity:1}80%{transform:translateY(2px) scale(.95);opacity:1}to{transform:translateY(0) scale(1);opacity:1}}@keyframes slamInE{0%{transform:translate(100px) scale(3);opacity:0}60%{transform:translate(0) scale(1);opacity:1}80%{transform:translate(-2px) scale(.95);opacity:1}to{transform:translate(0) scale(1);opacity:1}}@keyframes slamInS{0%{transform:translateY(100px) scale(3);opacity:0}60%{transform:translateY(0) scale(1);opacity:1}80%{transform:translateY(-2px) scale(.95);opacity:1}to{transform:translateY(0) scale(1);opacity:1}}@keyframes slamInW{0%{transform:translate(-100px) scale(3);opacity:0}60%{transform:translate(0) scale(1);opacity:1}80%{transform:translate(2px) scale(.95);opacity:1}to{transform:translate(0) scale(1);opacity:1}}@keyframes rightBowerPulse{0%{box-shadow:0 0 #fbbf24b3}60%{box-shadow:0 0 0 40px #fbbf2400}to{box-shadow:0 0 #fbbf2400}}.card-n.right-bower-anim{animation:slamInN .4s ease-out forwards,rightBowerPulse .8s .4s 1 forwards}.card-e.right-bower-anim{animation:slamInE .4s ease-out forwards,rightBowerPulse .8s .4s 1 forwards}.card-s.right-bower-anim{animation:slamInS .4s ease-out forwards,rightBowerPulse .8s .4s 1 forwards}.card-w.right-bower-anim{animation:slamInW .4s ease-out forwards,rightBowerPulse .8s .4s 1 forwards}.hand-container{width:100%;display:flex;justify-content:left;padding-left:2px;z-index:0;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}.player-hand-full{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:2px;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;min-height:70px}.inactive-hand{position:absolute;top:43%;left:45%;font-size:clamp(2rem,10vw,3rem);opacity:50%}.card-in-hand{color:var(--text-primary)}.card-in-hand.trump{color:var(--text-trump-hand)}.suit-icon-black{color:var(--color-black-suit);width:.9em;display:inline-block}.suit-icon-red{color:var(--color-red-suit);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:var(--bg-body);border:1px solid var(--border-medium);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:var(--bg-kitty-discard);border:1px solid var(--border-medium);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:var(--text-primary);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:var(--bg-card);width:clamp(23px,7vw,31.5px);height:clamp(35px,10vw,42px);font-size:clamp(.7rem,2.5vw,.9rem)}.kitty-card,.discard-card,.turned-down-upcard{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:var(--bg-unknown-card);color:var(--text-unknown-card);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%,var(--text-primary-fade) 46%,var(--text-primary-fade) 54%,transparent 54%);pointer-events:none;z-index:1}.in-the-wild-section{display:flex;flex-direction:column;align-items:center;gap:6px;border-top:1px solid var(--border-medium);padding-top:8px;margin-top:4px;width:100%}.in-the-wild-section:first-child{border-top:none;padding-top:0;margin-top:0}.in-the-wild-title{font-size:clamp(10.5px,2.5vw,12px);font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em}.in-the-wild-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px 12px;width:100%;min-width:60px}.in-the-wild-row{display:flex;align-items:center;gap:4px;font-size:clamp(.7rem 1vw .8rem)}.in-the-wild-icon{font-size:1.15rem;display:flex;justify-content:center;align-items:center}.in-the-wild-remaining{color:var(--text-secondary);font-size:clamp(.7rem 1vw .8rem);text-align:left;font-weight:600}.in-the-wild-remaining.trump-suit{color:var(--text-trump-hand)}
