html{overflow-x:hidden;overflow-y:auto;font-family:Arial,sans-serif;color:#fff;min-height:100vh;margin:0;padding:0}body{-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;min-height:100vh;position:relative;margin:0;padding:0;overflow-x:hidden;overflow-y:auto;background-color:#0d2818;background-image:url(/assets/felt-green-CieYw_4d.webp);background-repeat:repeat;background-size:400px 400px}#game-container{position:relative;width:100%;height:100vh;overflow:hidden}.card{position:relative;width:85px;height:119px;overflow:visible;cursor:pointer;flex-shrink:0}.card-back,.card-front{position:absolute;top:0;left:0;width:100%;height:100%;background-repeat:no-repeat;background-size:cover;background-position:center;border-radius:8px;pointer-events:none;box-shadow:0 2px 8px #0000004d}.card-shade{position:absolute;top:0;left:0;width:100%;height:100%;background:#000;border-radius:8px;opacity:0;transition:opacity .3s ease;pointer-events:none}.card-back{background-image:url(/assets/card_back-C1SCalpW.webp)}.card .card-back{display:block}.card .card-front{display:none}.card.face-up .card-front{display:block}.card.face-up .card-back{display:none}.card.card-back-only{width:80px;height:112px}.card.card-back-only .card-back{width:100%;height:100%}.card.playable{cursor:pointer}.card.disabled{pointer-events:none;cursor:not-allowed}#hand-south{position:absolute;bottom:15px;left:50%;transform:translate(-50%);height:135px;z-index:50;display:flex;justify-content:center;align-items:flex-end;overflow:visible;padding-top:15px}#hand-south .card{position:relative;margin-left:-18px}#hand-south .card:first-child{margin-left:0}.player-area{position:absolute;z-index:10}.player-info{display:flex;flex-direction:column;align-items:center;gap:2px;padding:0;background:transparent;min-width:80px}.player-avatar{width:55px;height:55px;border-radius:50%;border:3px solid #e3c370;object-fit:cover;box-shadow:0 4px 12px #00000080}.player-name{font-size:14px;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.8)}.partner-label{font-size:11px;color:#e3c370;text-shadow:0 1px 3px rgba(0,0,0,.8);margin-top:-2px}.player-bid-display,.player-tricks-display{font-size:12px;color:#ddd;text-shadow:0 1px 3px rgba(0,0,0,.8)}.bid-value,.tricks-value{font-weight:700;color:#e3c370}.player-south{bottom:35px;right:30px;left:auto;transform:none}.player-north{top:15px;left:50%;transform:translate(-50%)}.player-north .player-info{flex-direction:row;gap:12px;align-items:center}.player-north .player-details{display:flex;flex-direction:column;align-items:flex-start}.player-north .player-stats{display:flex;gap:15px}.player-west{left:20px;top:45%;transform:translateY(-50%)}.player-east{right:20px;top:50%;transform:translateY(-50%)}.player-area.current-turn .player-avatar{box-shadow:0 0 20px #e3c370cc;border-color:#f0d080}#opponent-cards-west,#opponent-cards-north,#opponent-cards-east{position:absolute;z-index:5;display:flex;justify-content:flex-start;width:320px}#opponent-cards-west{left:100px;top:50%;transform:translateY(-50%) rotate(90deg)}#opponent-cards-north{top:100px;left:50%;transform:translate(-50%)}#opponent-cards-east{right:100px;top:50%;transform:translateY(-50%) rotate(-90deg)}#opponent-cards-west .card,#opponent-cards-north .card,#opponent-cards-east .card{margin-left:-60px}#opponent-cards-west .card:first-child,#opponent-cards-north .card:first-child,#opponent-cards-east .card:first-child{margin-left:0}#trick-area{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:280px;height:240px;z-index:20}.trick-slot{position:absolute;width:100px;height:140px}.trick-slot .card{position:absolute;top:0;left:0}#trick-card-north{top:0;left:50%;transform:translate(-50%)}#trick-card-south{bottom:0;left:50%;transform:translate(-50%)}#trick-card-west{left:0;top:50%;transform:translateY(-50%)}#trick-card-east{right:0;top:50%;transform:translateY(-50%)}#scoreboard{position:absolute;top:5px;right:5px;background:url(/assets/scroll-menu-Rngv_IAD.webp) no-repeat center center;background-size:100% 100%;border-radius:0;padding:18px 22px 22px;min-width:160px;max-width:180px;z-index:60;font-size:11px;transform:scale(.85);transform-origin:top right}.scoreboard-header{font-family:Cinzel,serif;font-size:14px;font-weight:800;color:#1a0f05;text-align:center;margin-bottom:10px;letter-spacing:2px;text-shadow:0 1px 0 rgba(255,255,255,.3)}.team-score{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:baseline;padding:3px 0;border-bottom:1px solid rgba(60,40,20,.2)}.team-label{font-family:Cinzel,serif;color:#1a0f05;font-weight:700;font-size:11px;text-shadow:0 1px 0 rgba(255,255,255,.3)}.team-score-value{font-family:Cinzel,serif;font-size:20px;font-weight:800;color:#1a0f05;text-shadow:0 1px 0 rgba(255,255,255,.3)}.team-bags{font-size:10px;color:#3d2914;font-weight:600;width:100%;text-align:right}.contract-display{margin-top:8px;font-size:10px}.contract-row{display:flex;justify-content:space-between;padding:2px 0;color:#1a0f05;font-family:Cinzel,serif;font-weight:600}.contract-row span:last-child{color:#1a0f05;font-weight:800}#game-status{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000d9;border:2px solid #e3c370;border-radius:12px;padding:15px 30px;z-index:70;text-align:center;font-size:18px;font-weight:600}#game-status.hidden{display:none}#turn-indicator{position:absolute;bottom:200px;left:50%;transform:translate(-50%);background:#000000b3;border-radius:8px;padding:8px 16px;font-size:14px;z-index:55}#turn-indicator.hidden{display:none}.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#000000d9;z-index:200;opacity:1;transition:opacity .3s ease}.modal.hidden{opacity:0;pointer-events:none}.modal-content{background:linear-gradient(145deg,#1a5024,#0d2818);border:3px solid #e3c370;border-radius:20px;padding:30px 40px;max-width:90vw;max-height:90vh;overflow-y:auto;text-align:center;box-shadow:0 10px 40px #00000080}.modal-close{position:absolute;top:15px;right:20px;background:none;border:none;color:#f0f0f0;font-size:32px;cursor:pointer;opacity:.7;transition:opacity .2s}.modal-close:hover{opacity:1}.scroll-menu-container{position:relative;max-width:550px;width:95vw}.scroll-bg{width:100%;height:auto;display:block;filter:drop-shadow(0 15px 40px rgba(0,0,0,.6))}.scroll-content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12% 15% 8%}.scroll-content h1{font-family:Cinzel,serif;font-size:clamp(1.8rem,6vw,2.5rem);color:#000!important;text-shadow:none;margin:0;letter-spacing:.08em;-webkit-text-fill-color:#000}.scroll-content h1 .spade-icon{color:#000!important;-webkit-text-fill-color:#000;font-size:.85em}.scroll-content .tagline{font-family:Cinzel,serif;font-size:clamp(.9rem,2.5vw,1.1rem);color:#000!important;-webkit-text-fill-color:#000;margin:8px 0 25px;font-style:normal;font-weight:500}.menu-buttons{display:flex;flex-direction:column;gap:12px;width:100%;max-width:240px}.scroll-btn{padding:12px 24px;font-family:Cinzel,serif;font-size:16px;font-weight:600;border:2px solid #5a4025;border-radius:6px;cursor:pointer;transition:all .2s ease;background:#5a402526;color:#1a0f05}.scroll-btn:hover{background:#5a40254d;transform:translateY(-2px)}.scroll-btn.primary{background:#5a4025;color:#f5e6c8;border-color:#3d2914}.scroll-btn.primary:hover{background:#3d2914;transform:translateY(-2px)}.candle-container{position:absolute;top:-45px;right:20px;width:100px;height:auto;z-index:25;pointer-events:none}.candle-image{width:100%;height:auto;filter:drop-shadow(0 10px 20px rgba(0,0,0,.5));position:relative;z-index:2}.candle-glow{position:absolute;top:5%;left:45%;transform:translate(-50%);width:80px;height:100px;background:radial-gradient(ellipse 70% 90% at 50% 30%,rgba(255,200,120,.3) 0%,rgba(255,170,80,.15) 35%,rgba(255,140,50,.05) 65%,transparent 100%);border-radius:50%;pointer-events:none;z-index:1;filter:blur(8px);animation:candleFlicker 4s ease-in-out infinite}@keyframes candleFlicker{0%,to{opacity:.85}33%{opacity:.7}66%{opacity:.95}}#main-menu .modal-content{min-width:320px}#main-menu h1{font-size:36px;color:#e3c370;margin-bottom:5px;text-shadow:2px 2px 4px rgba(0,0,0,.5)}#main-menu .tagline{color:#aaa;margin-bottom:25px;font-size:14px}.menu-btn{display:block;width:100%;padding:14px 24px;margin:10px 0;font-size:16px;font-weight:600;border:2px solid #e3c370;border-radius:10px;cursor:pointer;transition:all .2s ease;background:transparent;color:#f0f0f0}.menu-btn:hover{background:#e3c37033;transform:translateY(-2px)}.menu-btn.primary{background:#e3c370;color:#0d2818}.menu-btn.primary:hover{background:#f0d080;transform:translateY(-2px)}.bidding-content h2{color:#e3c370;margin-bottom:10px}.bidding-info{color:#aaa;margin-bottom:20px}.bid-buttons{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;max-width:350px;margin:0 auto 20px}.bid-btn{padding:12px 8px;font-size:16px;font-weight:600;background:#ffffff1a;border:2px solid #e3c370;border-radius:8px;color:#f0f0f0;cursor:pointer;transition:all .2s}.bid-btn:hover{background:#e3c370;color:#0d2818}.bid-btn[data-bid="0"]{grid-column:span 5;background:#dc354533;border-color:#dc3545}.bid-btn[data-bid="0"]:hover{background:#dc3545;color:#fff}#partner-bid-info{color:#4ecdc4;font-size:14px;padding:10px;background:#4ecdc41a;border-radius:8px}#partner-bid-info.hidden{display:none}.rules-content{max-width:500px;text-align:left;position:relative}.rules-content h2{color:#e3c370;text-align:center;margin-bottom:20px}.rules-content h3{color:#4ecdc4;margin-top:20px;margin-bottom:10px;font-size:16px}.rules-content p,.rules-content li{color:#ccc;line-height:1.6;font-size:14px}.rules-content ul{padding-left:20px}.rules-scroll{max-height:60vh;overflow-y:auto;padding-right:10px}.settings-content{min-width:300px;position:relative}.settings-content h2{color:#e3c370;margin-bottom:25px}.setting-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.1)}.setting-row label{font-size:14px;color:#f0f0f0}.toggle-btn{padding:8px 20px;border:2px solid #e3c370;border-radius:6px;background:transparent;color:#f0f0f0;cursor:pointer;font-weight:600;transition:all .2s}.toggle-btn.on{background:#228b27;border-color:#228b27}#card-speed{padding:8px 12px;border:2px solid #e3c370;border-radius:6px;background:#0000004d;color:#f0f0f0;font-size:14px;cursor:pointer}.round-end-content h2{color:#e3c370;margin-bottom:20px}#round-results{text-align:left;margin-bottom:20px}.round-result-row{padding:12px;margin:10px 0;background:#0000004d;border-radius:8px;line-height:1.6}.round-result-row strong{color:#4ecdc4}.round-totals{padding-top:15px;border-top:1px solid rgba(255,255,255,.2);font-size:16px;font-weight:600}.game-over-content h2{font-size:28px;margin-bottom:15px}#game-over-message{color:#aaa;margin-bottom:20px}#final-scores{font-size:18px;margin-bottom:25px}#final-scores p{margin:8px 0}@media(max-width:768px){.card,.card-back,.card-front{width:80px;height:112px}#hand-south{bottom:15px;height:130px}.player-south{bottom:155px}.player-info{padding:8px 12px;min-width:75px}.player-avatar{width:40px;height:40px}.player-name{font-size:12px}#scoreboard{font-size:11px;padding:10px 12px;min-width:150px}.trick-slot{width:80px;height:112px}#trick-area{width:220px;height:200px}}@media(max-width:480px){.card,.card-back,.card-front{width:65px;height:91px}.player-info{padding:6px 10px;min-width:65px}.player-avatar{width:35px;height:35px}.trick-slot{width:65px;height:91px}#trick-area{width:180px;height:160px}.modal-content{padding:20px 25px}.bid-buttons{grid-template-columns:repeat(4,1fr)}.bid-btn[data-bid="0"]{grid-column:span 4}}
