.card{width:var(--card-width);height:var(--card-height);border-radius:var(--card-radius);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;flex-shrink:0}.card:hover{transform:translateY(-2px)}.card--empty{background:#ffffff1a;border:2px dashed rgba(255,255,255,.3)}.card--face-down{background:linear-gradient(135deg,#2c3e50,#34495e);border:2px solid #1a252f;box-shadow:var(--card-shadow)}.card--face-down.card--player1{background:linear-gradient(135deg,#8b0000,#b22222);border-color:#5c0000}.card--face-down.card--player2{background:linear-gradient(135deg,#00008b,#4169e1);border-color:#00005c}.card--face-up{background:transparent;box-shadow:var(--card-shadow);overflow:hidden}.card--selected{transform:translateY(-4px);box-shadow:0 4px 12px #0006,0 0 0 3px gold}.card--valid-target{box-shadow:0 0 0 3px #4caf50}.card--valid-target.card--empty{background:#4caf5033;border-color:#4caf50}.card--hint{box-shadow:0 0 8px 2px #f9a825cc,0 0 0 2px #f9a825;animation:hint-pulse 1.5s ease-in-out infinite}@keyframes hint-pulse{0%,to{box-shadow:0 0 8px 2px #f9a825cc,0 0 0 2px #f9a825}50%{box-shadow:0 0 12px 4px #f9a82599,0 0 0 2px #f9a825}}.card__image{width:100%;height:100%;object-fit:contain;pointer-events:none}.pile{display:flex;flex-direction:column;align-items:center;gap:4px}.pile__label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;opacity:.7;white-space:nowrap}.pile__stack{position:relative}.pile__count{position:absolute;bottom:-8px;right:-8px;background:#000000b3;color:#fff;font-size:11px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:20px;text-align:center}@media (min-width: 768px){.pile__label{font-size:11px}}.tableau-pile{position:relative;height:var(--card-height);width:var(--card-width)}.tableau-pile__card{position:absolute;top:0}.tableau-pile--left .tableau-pile__card{right:calc(var(--index, 0) * 16px)}.tableau-pile--right .tableau-pile__card{left:calc(var(--index, 0) * 16px)}@media (min-width: 768px){.tableau-pile--left .tableau-pile__card{right:calc(var(--index, 0) * 20px)}.tableau-pile--right .tableau-pile__card{left:calc(var(--index, 0) * 20px)}}.foundation-pile{width:var(--card-width);height:var(--card-height)}.foundation-pile--empty{background:#ffffff0d;border:2px dashed rgba(255,255,255,.3);border-radius:var(--card-radius);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease,border-color .2s ease}.foundation-pile--empty:hover{background:#ffffff1a}.foundation-pile--valid-target{background:#4caf5033;border-color:#4caf50}.foundation-pile__suit-icon{width:40%;height:40%;opacity:.4;pointer-events:none}.game-board{flex:1;display:flex;flex-direction:column;padding:8px 8px 48px;gap:8px;overflow:hidden}.player-area{display:flex;align-items:center;justify-content:center;gap:var(--pile-gap);padding:8px;border-radius:8px;background:#0000001a;transition:background .2s ease}.player-area--active{background:#ffd70026;box-shadow:inset 0 0 0 2px #ffd7004d}.middle-area{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:var(--card-gap);padding:8px 0;overflow:visible}.middle-row{display:grid;grid-template-columns:var(--card-width) var(--card-width) var(--card-width) var(--card-width);gap:var(--card-gap);align-items:center;justify-content:center}.middle-row>*{overflow:visible}@media (min-width: 768px){.game-board{padding:16px 16px 56px;gap:12px}.player-area{padding:12px;gap:calc(var(--pile-gap) * 2)}.middle-area,.middle-row{gap:var(--pile-gap)}}.game-status{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:#0000004d;gap:16px;flex-wrap:wrap}.game-status__info{display:flex;align-items:center;gap:16px}.game-status__turn{font-weight:700;font-size:14px}.game-status__winner{font-weight:700;font-size:16px;color:gold}.game-status__moves{font-size:12px;opacity:.8}.game-status__scores{display:flex;gap:16px}.game-status__score{font-size:12px;padding:4px 8px;border-radius:4px;background:#ffffff1a}.game-status__score--p1{color:#ff6b6b}.game-status__score--p2{color:#69b7ff}.game-status__button{padding:8px 16px;border:none;border-radius:4px;background:#4caf50;color:#fff;font-weight:700;cursor:pointer;transition:background .2s ease,opacity .2s ease}.game-status__button:hover:not(:disabled){background:#45a049}.game-status__button:disabled{opacity:.5;cursor:not-allowed}.game-status__button--hints{background:#666}.game-status__button--hints:hover{background:#555}.game-status__button--hints.game-status__button--active{background:#f9a825;color:#000}.game-status__button--hints.game-status__button--active:hover{background:#f57f17}.game-status__button--undo{margin-left:auto;background:#666}.game-status__button--undo:hover:not(:disabled){background:#555}@media (min-width: 768px){.game-status{padding:12px 24px}.game-status__turn{font-size:16px}.game-status__moves,.game-status__score{font-size:14px}}.history-toggle{position:fixed;bottom:8px;left:50%;transform:translate(-50%);background:#000000b3;border:1px solid rgba(255,255,255,.2);color:#fff;padding:6px 16px;border-radius:16px;font-size:12px;cursor:pointer;z-index:100;transition:background .2s ease}.history-toggle:hover{background:#000000d9}.history-sheet{position:fixed;bottom:0;left:0;right:0;background:#000000e6;border-top:1px solid rgba(255,255,255,.2);border-radius:16px 16px 0 0;transform:translateY(100%);transition:transform .3s ease;z-index:99;max-height:40vh;overflow:hidden}.history-sheet--open{transform:translateY(0)}.history-sheet__content{padding:48px 16px 16px;max-height:40vh;overflow-y:auto}.history-sheet__empty{text-align:center;opacity:.5;padding:20px}.history-sheet__moves{display:flex;flex-wrap:wrap;gap:8px;font-family:monospace;font-size:13px}.history-sheet__move{background:#ffffff1a;padding:4px 8px;border-radius:4px;display:inline-flex;gap:4px}.history-sheet__move-num{opacity:.5}@media (min-width: 768px){.history-toggle{bottom:12px;padding:8px 20px;font-size:13px}.history-sheet__content{padding:56px 24px 24px}.history-sheet__moves{font-size:14px;gap:10px}}.animating-card{position:fixed;z-index:1000;pointer-events:none;border-radius:var(--card-radius, 8px);box-shadow:0 8px 24px #0006}.animating-card__image{width:100%;height:100%;display:block;border-radius:var(--card-radius, 8px)}.app{height:100%;display:flex;flex-direction:column;background:linear-gradient(135deg,var(--bg-color) 0%,var(--felt-color) 100%)}*{box-sizing:border-box;margin:0;padding:0}:root{--card-width: 60px;--card-height: 84px;--card-radius: 6px;--card-gap: 8px;--pile-gap: 12px;--bg-color: #1a472a;--felt-color: #2d5a3d;--card-shadow: 0 2px 4px rgba(0, 0, 0, .3)}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:var(--bg-color);color:#fff;touch-action:manipulation;-webkit-user-select:none;user-select:none}@media (min-width: 768px){:root{--card-width: 70px;--card-height: 98px;--card-radius: 8px;--card-gap: 10px;--pile-gap: 16px}}@media (min-width: 1024px){:root{--card-width: 80px;--card-height: 112px;--card-gap: 12px;--pile-gap: 20px}}
