:root{--bg-deep: #050810;--bg-panel: rgba(12, 20, 40, .85);--border-glow: rgba(0, 240, 255, .35);--accent: #00f0ff;--accent-2: #7b2fff;--text: #e8f4ff;--text-muted: #7a9bb8;--suit-oros: #d4a017;--suit-copas: #c43c3c;--suit-black: #1a1a2e;--card-paper: #f4ecd8;--danger: #ff4477;--radius: 14px;--card-w: 80px;--card-h: 118px;font-family:Rajdhani,system-ui,sans-serif}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;color:var(--text);background:var(--bg-deep);background-image:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(0,240,255,.12),transparent),radial-gradient(ellipse 60% 40% at 100% 100%,rgba(123,47,255,.15),transparent),linear-gradient(180deg,#050810,#0a1224)}#root{min-height:100vh}.app{max-width:520px;margin:0 auto;padding:1rem 1rem 2rem;min-height:100vh;display:flex;flex-direction:column;gap:1rem}.menu-screen,.game-screen{--room-bg-url: url(/bg/truco-royale-room.png?v=whatsapp-1);--room-bg-size: 100% auto;--room-bg-position: center top}.menu-screen{background-color:#0d0806;background-image:linear-gradient(180deg,#050810bf,#05081099),var(--room-bg-url);background-position:var(--room-bg-position);background-size:var(--room-bg-size);background-repeat:no-repeat}h1{font-family:Orbitron,sans-serif;font-size:2.75rem;letter-spacing:.2em;margin:0;background:linear-gradient(90deg,var(--accent),var(--accent-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.eyebrow{text-transform:uppercase;letter-spacing:.25em;font-size:.75rem;color:var(--accent);margin:0}.subtitle{color:var(--text-muted);margin:.25rem 0 0}.panel{background:var(--bg-panel);border:1px solid var(--border-glow);border-radius:var(--radius);padding:1.25rem;display:flex;flex-direction:column;gap:1rem;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 0 40px #00f0ff0f}.field{display:flex;flex-direction:column;gap:.35rem;font-weight:600}.field select{background:#0006;border:1px solid var(--border-glow);color:var(--text);padding:.6rem .75rem;border-radius:8px;font-family:inherit;font-size:1rem}.field-hint{margin:0;font-size:.8rem;font-weight:500;color:var(--text-muted);line-height:1.35}.field.checkbox{flex-direction:row;align-items:center;gap:.5rem;color:var(--text-muted);font-weight:500}.skin-preview{display:flex;gap:.35rem;justify-content:center;align-items:flex-end;padding-top:.35rem;min-height:5.5rem}.skin-picker{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.skin-picker-option{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.55rem .4rem .65rem;border-radius:10px;border:2px solid rgba(255,255,255,.12);background:#00000059;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s}.skin-picker-option:hover{border-color:#d4af3773}.skin-picker-option--selected{border-color:#d4af37;box-shadow:0 0 16px #d4af3759;background:#4a18188c}.skin-picker-label{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:#f0d878}.skin-preview-card{width:52px;aspect-ratio:1 / 1.46;object-fit:contain;border-radius:6px;border:1px solid rgba(184,150,58,.55);background:#fff;box-shadow:2px 3px 8px #00000059;transform:rotate(var(--preview-rotate, 0deg))}.field--skin>span{display:block;margin-bottom:.35rem}.btn{font-family:Orbitron,sans-serif;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;border:none;border-radius:8px;padding:.65rem 1rem;cursor:pointer;transition:transform .15s,box-shadow .15s}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--accent),#0088aa);color:#001018;box-shadow:0 0 20px #00f0ff59}.btn-secondary{background:#7b2fff59;color:var(--text);border:1px solid rgba(123,47,255,.6)}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid rgba(255,255,255,.15)}.btn-mazo{background:linear-gradient(180deg,#c94a3f,#8f2822);border:1px solid #e87870;color:#fff;font-weight:700;text-transform:uppercase;box-shadow:0 2px 10px #00000059}.btn-mazo:not(:disabled):hover{filter:brightness(1.08)}.action-group--full{width:100%;justify-content:center}.hand-respond-bar{display:flex;flex-wrap:wrap;gap:.45rem;justify-content:center;align-items:center;margin-bottom:.4rem;padding:.45rem .55rem;border-radius:10px;background:#000000c7;border:1px solid rgba(255,255,255,.18);box-shadow:0 4px 20px #0000008c;pointer-events:auto}.btn-respond-quiero{background:linear-gradient(180deg,#5cb85c,#2d7a2d);border:1px solid #7fd67f;color:#fff;font-weight:700;padding:.45rem 1rem;font-size:.72rem;letter-spacing:.05em;border-radius:6px;box-shadow:0 2px 12px #0006}.btn-respond-no{background:linear-gradient(180deg,#e84a4a,#a82020);border:1px solid #ff7a6a;color:#fff;font-weight:700;padding:.45rem 1rem;font-size:.72rem;letter-spacing:.05em;border-radius:6px;box-shadow:0 2px 12px #b41e1e73}.action-calls-row{display:flex;flex-direction:row;align-items:center;justify-content:space-between;width:100%;gap:.25rem;min-height:1.75rem}.action-calls-lane{display:flex;flex-wrap:nowrap;gap:.2rem;align-items:center;flex:1;min-width:0}.action-calls-lane--envido{justify-content:flex-start}.action-calls-lane--truco{justify-content:flex-end}.btn-canto-envido{background:linear-gradient(180deg,#f5d547,#c9a020);border:1px solid #ffe566;color:#3d2800;font-weight:700;white-space:nowrap}.btn-canto-truco{background:linear-gradient(180deg,#4a7ab8,#2a5088);border:1px solid #6eb8ff;color:#fff;font-weight:700;white-space:nowrap}.btn-canto-truco--raise{font-size:.5rem;padding:.28rem .4rem}.action-mazo-row{display:flex;justify-content:center;align-items:center;width:100%;margin-top:.25rem;padding-top:.2rem}.action-dock-inner{display:flex;flex-direction:column;gap:.25rem;width:100%}.btn-large{width:100%;padding:1rem;font-size:.95rem}.btn-small{padding:.4rem .6rem;font-size:.65rem}.btn:not(:disabled):hover{transform:translateY(-1px)}.hud{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.scores{flex:1;display:flex;align-items:center;gap:.5rem;font-family:Orbitron,sans-serif;font-size:1.1rem}.score.you{color:var(--accent)}.score.ia{color:var(--accent-2)}.badge{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;padding:.25rem .5rem;border-radius:4px;background:#7b2fff4d;border:1px solid rgba(123,47,255,.5)}.app.game-screen{position:relative;width:100%;max-width:480px;margin:0 auto;padding:0;gap:0;min-height:100svh;overflow-x:hidden}.game-screen{--table-top: 54%;--table-w: 86%;--table-h: 26%;--table-tilt: 5deg;--trick-card-w: min(13vw, 58px);--trick-card-h: calc(var(--trick-card-w) * 1.46);--hand-dock-bottom: 5rem;--rival-hand-top: 17%;--rival-play-top: 38%;--trick-pile-top: 40%;--trick-overlap: .1;--call-center-top: 48%;position:relative;width:100%;max-width:480px;margin:0 auto;min-height:100svh;overflow-x:hidden;display:block;background-color:#0d0806;background-image:linear-gradient(180deg,rgba(0,0,0,.25) 0%,transparent 35%,transparent 65%,rgba(0,0,0,.45) 100%),var(--room-bg-url);background-position:var(--room-bg-position);background-size:var(--room-bg-size);background-repeat:no-repeat}@media(max-height:700px){.game-screen{--table-top: 52%;--table-h: 24%;--rival-hand-top: 15%;--hand-dock-bottom: 4.75rem}}body:has(.game-screen){background:#0d0806}.game-screen .game-hud{position:absolute;top:0;left:0;right:0;display:grid;grid-template-columns:auto 1fr auto 1fr auto;align-items:center;gap:.35rem;padding:.5rem .65rem;padding-top:max(.5rem,env(safe-area-inset-top,0px));background:linear-gradient(180deg,#000000d1,#00000059);z-index:25;pointer-events:auto}.game-screen .game-stake-badge{position:absolute;top:calc(3.1rem + env(safe-area-inset-top,0px));right:.5rem;z-index:26;margin:0;padding:.25rem .5rem;border-radius:6px;font-size:.65rem;font-weight:700;letter-spacing:.04em;color:#f5d878;background:#000000a6;pointer-events:none}.game-screen .game-turn-timer{position:absolute;top:calc(3.1rem + env(safe-area-inset-top,0px));left:50%;transform:translate(-50%);z-index:26;margin:0;padding:.3rem .65rem;border-radius:8px;font-family:Orbitron,sans-serif;font-size:.75rem;font-weight:700;color:#fff;background:#c83232d9;box-shadow:0 2px 12px #00000073;pointer-events:none}.game-screen .game-online-notice{position:absolute;top:calc(3.25rem + env(safe-area-inset-top,0px));left:50%;transform:translate(-50%);z-index:26;margin:0;padding:.35rem .75rem;border-radius:8px;background:#000000bf;font-size:.8rem;white-space:nowrap;pointer-events:none}.hud-icon-btn{width:36px;height:36px;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:#00000073;color:#fff;font-size:1.1rem;cursor:pointer}.hud-exit{color:#ff8ab0;border-color:#ff649673}.player-score{display:flex;align-items:center;gap:.35rem}.player-score--you{justify-self:start}.player-score--rival{justify-self:end}.score-chip{min-width:2.1rem;padding:.2rem .55rem;border-radius:6px;font-family:Orbitron,sans-serif;font-weight:700;font-size:1.15rem;text-align:center;box-shadow:0 2px 8px #0006}.score-chip--you{background:linear-gradient(180deg,#f5d547,#c9a020);color:#3d2800}.score-chip--rival{background:linear-gradient(180deg,#6eb8ff,#2a6eb8);color:#fff}.avatar{width:44px;height:44px;border-radius:10px;display:grid;place-items:center;font-size:1.35rem;border:3px solid;box-shadow:0 4px 12px #00000073}.avatar--you{border-color:#f5d547;background:linear-gradient(145deg,#4a3818,#2a1a08)}.avatar--rival{border-color:#e878b8;background:linear-gradient(145deg,#4a1848,#2a0828)}.hud-mano{justify-self:center}.mano-chip{padding:.25rem .55rem;border-radius:999px;font-size:.68rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:#c8d4e8;background:#00000059;border:1px solid rgba(255,255,255,.15);white-space:nowrap}.mano-chip--you{color:#ffe9a8;border-color:#d4af37;background:#3c280a8c}.target-chip{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;background:linear-gradient(180deg,#3a5a8a,#1a3058);border:2px solid #6eb8ff;font-family:Orbitron,sans-serif;font-weight:700;font-size:.85rem;color:#fff;justify-self:end}.game-screen>.table-arena{min-height:0;pointer-events:none}.table-arena{position:absolute;left:50%;top:var(--table-top);z-index:5;width:var(--table-w);height:var(--table-h);padding:0;overflow:visible;pointer-events:auto;transform:translate(-50%,-50%) perspective(820px) rotateX(var(--table-tilt));transform-style:preserve-3d}.table-arena.drag-over .round-table{filter:brightness(1.06)}.table-arena.table-arena--dragging{z-index:25}.table-arena.table-arena--dragging .round-table{pointer-events:auto}.card-drop-zone{position:absolute;left:4%;right:4%;top:32%;bottom:28%;z-index:14;pointer-events:auto}.card-drop-zone--over{background:#f5d5470f;outline:2px dashed rgba(245,213,71,.45);outline-offset:-4px}.table-drop-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;margin:0;padding:.35rem;font-size:.62rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#f5d547;text-shadow:0 1px 8px #000;background:#00000059;border-radius:8px;border:2px dashed rgba(245,213,71,.65);pointer-events:none}.round-table{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;box-sizing:border-box;background:transparent;display:block;pointer-events:none}.table-felt-logo{display:none}.game-screen .call-center{position:absolute;top:var(--call-center-top);left:50%;transform:translate(-50%,-50%);z-index:15;width:92%;max-width:100%;display:flex;flex-direction:column;align-items:center;gap:.3rem;pointer-events:none;filter:drop-shadow(0 4px 20px rgba(0,0,0,.65))}.game-screen .call-center--with-rival-response{gap:.22rem}.game-screen .call-center--round-end-flash{z-index:21}.call-banner{position:relative;top:auto;left:auto;transform:none;margin:0;width:100%;padding:.45rem .75rem;text-align:center;font-family:Orbitron,sans-serif;font-size:clamp(1.1rem,5vw,1.45rem);font-weight:700;letter-spacing:.2em;border-radius:8px;z-index:1;pointer-events:none}.call-banner--envido{color:#3d2800;background:linear-gradient(180deg,#f5d547,#c9a020);border:1px solid #ffe566;box-shadow:0 4px 18px #00000073;text-shadow:0 1px 0 rgba(255,255,255,.25)}.call-banner--truco{color:#fff;background:linear-gradient(180deg,#4a7ab8,#2a5088);border:1px solid #6eb8ff;box-shadow:0 4px 18px #00000073;text-shadow:0 1px 4px rgba(0,0,0,.35)}.game-screen .call-center .call-bubble{position:relative;top:auto;right:auto;bottom:auto;left:auto;transform:none}.game-screen .call-center .call-bubble:after{display:none}.call-response{display:flex;flex-direction:column;align-items:center;gap:.15rem;margin:0;padding:.4rem 1rem .5rem;border-radius:14px;background:#0000008c;box-shadow:0 4px 18px #00000073;animation:call-response-in .25s ease-out}.call-response-who{font-size:.55rem;text-transform:uppercase;letter-spacing:.14em;color:#ffffffa6}.call-response-text{font-family:Orbitron,sans-serif;font-size:clamp(1.15rem,5.5vw,1.55rem);font-weight:700;letter-spacing:.08em;color:#ffe9a8;text-shadow:0 2px 8px rgba(0,0,0,.6)}.call-response--rival .call-response-text{color:#b8f0c8}.call-response--hint{font-size:clamp(.75rem,3.2vw,.9rem);font-weight:600;letter-spacing:.04em;color:#e8f4ffe0;text-align:center;line-height:1.35;max-width:16rem}.call-response--quiero{font-family:Orbitron,sans-serif;font-size:clamp(1rem,5vw,1.35rem);font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:linear-gradient(180deg,#5cb85c,#2d7a2d);border:1px solid #7fd67f;box-shadow:0 4px 16px #28783273}.call-response--no{font-family:Orbitron,sans-serif;font-size:clamp(1rem,5vw,1.35rem);font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:linear-gradient(180deg,#e84a4a,#a82020);border:1px solid #ff7a6a;box-shadow:0 4px 16px #a01e1e80}@keyframes call-response-in{0%{opacity:0;transform:translateY(6px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.call-bubble{position:absolute;margin:0;padding:.25rem .65rem;border-radius:12px;font-weight:700;font-size:.8rem;background:#fff;color:#c9a020;box-shadow:0 4px 14px #00000073;z-index:6;pointer-events:none}.call-bubble:after{content:"";position:absolute;width:0;height:0;border:6px solid transparent}.call-bubble--you{bottom:28%;left:50%;transform:translate(-50%)}.call-bubble--you:after{bottom:-10px;left:50%;transform:translate(-50%);border-top-color:#fff}.call-bubble--rival{top:22%;right:18%}.call-bubble--rival:after{top:-10px;right:12px;border-bottom-color:#fff}.table-meta{position:absolute;top:8%;left:50%;transform:translate(-50%);margin:0;display:flex;gap:.5rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:#ffffffbf;text-shadow:0 1px 4px #000}.game-screen .rival-hand-zone{position:absolute;top:var(--rival-hand-top);left:50%;transform:translate(-50%);z-index:9;display:flex;flex-direction:column;align-items:center;gap:.25rem;max-height:28%;pointer-events:none}.game-screen .call-center .rival-call-response{order:-1;z-index:2;margin-bottom:.05rem}.rival-call-response{display:flex;flex-direction:column;align-items:center;gap:.05rem;padding:.28rem .75rem .32rem;border-radius:12px;border:1.5px solid rgba(255,255,255,.3);background:#000000c7;box-shadow:0 4px 16px #00000080;animation:rival-response-pop .3s cubic-bezier(.22,1.1,.36,1)}.rival-call-response--yes{border-color:#7fd67f;background:linear-gradient(180deg,#5cb85c,#2d7a2d);box-shadow:0 4px 18px #00000073,0 0 16px #50c85a59;animation:rival-response-pop .3s cubic-bezier(.22,1.1,.36,1),rival-response-glow-yes 1.6s ease-in-out infinite alternate}.rival-call-response--no{border-color:#ff7a6a;background:linear-gradient(180deg,#e84a4a,#a82020);box-shadow:0 4px 18px #00000073,0 0 16px #dc3c3266;animation:rival-response-pop .3s cubic-bezier(.22,1.1,.36,1),rival-response-glow-no 1.6s ease-in-out infinite alternate}.rival-call-response--son-buenas{border-color:#e8c84a;background:linear-gradient(180deg,#c9a227,#8a6b12);box-shadow:0 4px 18px #00000073,0 0 16px #e6be3c59;animation:rival-response-pop .3s cubic-bezier(.22,1.1,.36,1),rival-response-glow-son-buenas 1.6s ease-in-out infinite alternate}.rival-call-response-who{font-size:.45rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#ffffffa6}.rival-call-response-text{font-family:Orbitron,sans-serif;font-size:clamp(.95rem,4.8vw,1.25rem);font-weight:800;letter-spacing:.1em;line-height:1.1;text-transform:uppercase;color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.7)}.rival-call-response--yes .rival-call-response-text,.rival-call-response--no .rival-call-response-text{color:#fff}@keyframes rival-response-pop{0%{opacity:0;transform:translateY(10px) scale(.88)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes rival-response-glow-yes{0%{box-shadow:0 4px 18px #00000073,0 0 12px #50ff9640}to{box-shadow:0 4px 18px #00000073,0 0 22px #78ffb473}}@keyframes rival-response-glow-no{0%{box-shadow:0 4px 18px #00000073,0 0 12px #ff5a7838}to{box-shadow:0 4px 18px #00000073,0 0 22px #ff789666}}@keyframes rival-response-glow-son-buenas{0%{box-shadow:0 4px 18px #00000073,0 0 12px #e6be3c38}to{box-shadow:0 4px 18px #00000073,0 0 22px #ffdc646b}}.game-screen .opponent-on-table{transform:rotate(-3deg)}.game-screen .opponent-on-table .card-back-stack .playing-card{--card-w: 44px;--card-h: 65px;filter:drop-shadow(0 4px 10px rgba(0,0,0,.55))}.game-screen .rival-hand-zone .envido-hand-badge{max-width:min(92vw,11rem);font-size:.85em}.game-screen .table-trick-piles{position:absolute;top:var(--trick-pile-top);left:50%;transform:translate(-50%);display:flex;flex-direction:row;align-items:flex-start;justify-content:center;gap:clamp(.35rem,3.5vw,1.75rem);width:86%;max-width:100%;z-index:7;pointer-events:none}.envido-hand-badge{display:flex;flex-direction:column;align-items:center;gap:.1rem;padding:.35rem .9rem .4rem;border-radius:14px;background:#081220eb;box-shadow:0 4px 16px #0000008c,0 0 0 1px #ffffff14;pointer-events:none}.envido-hand-badge-label{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#ffffffb8}.envido-hand-badge-value{font-family:Orbitron,sans-serif;font-size:clamp(1.35rem,6vw,1.75rem);font-weight:800;line-height:1;letter-spacing:.04em}.envido-hand-badge--rival{border:2px solid rgba(255,190,100,.65)}.envido-hand-badge--rival .envido-hand-badge-value{color:#ffd88a;text-shadow:0 0 12px rgba(255,200,80,.45)}.envido-hand-badge--you{border:2px solid rgba(100,210,255,.65)}.envido-hand-badge--you .envido-hand-badge-value{color:#9ee8ff;text-shadow:0 0 12px rgba(80,200,255,.4)}.envido-hand-badge--pending{opacity:.92;border-style:dashed}.game-screen .hand-dock .envido-hand-badge{margin-bottom:.15rem}.envido-showdown{position:absolute;top:58%;left:50%;transform:translate(-50%,-50%);z-index:4;display:flex;flex-direction:column;align-items:center;gap:.35rem;pointer-events:none;text-align:center;max-width:88%}.envido-showdown-hint{margin:0;font-size:.72rem;color:#ffffffd9;text-shadow:0 1px 4px #000}.envido-on-table{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:4;display:flex;flex-direction:column;align-items:center;gap:.35rem;pointer-events:none;max-width:92%}.envido-on-table .round-end-banner--over-cards{position:relative;top:auto;left:auto;transform:none;margin:0 0 .15rem}.envido-on-table .envido-on-table-title.call-banner{width:auto;font-size:clamp(.65rem,3vw,.8rem);letter-spacing:.14em;padding:.35rem .75rem}.envido-winning-cards{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:.25rem}.envido-winning-cards .playing-card{--card-w: min(16vw, 72px);--card-h: calc(var(--card-w) * 1.46);box-shadow:0 4px 14px #00000073}.envido-on-table--scores-only .envido-on-table-title{margin-bottom:.15rem}.envido-on-table-totals{margin:0;font-size:.68rem;color:#ffffffe6;text-shadow:0 1px 4px #000;text-align:center}.round-end-banner--over-cards{position:absolute;top:calc(var(--call-center-top) - 5.75rem);left:50%;transform:translate(-50%);z-index:19;margin:0;padding:.4rem 1rem;font-family:Rajdhani,system-ui,sans-serif;font-size:clamp(.72rem,3.4vw,.88rem);font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#fff;text-align:center;text-shadow:none;white-space:nowrap;background:linear-gradient(180deg,#2563c8,#143d8a);border:1px solid rgba(255,255,255,.35);border-radius:10px;box-shadow:0 4px 18px #00000073,0 0 0 1px #00000026 inset;pointer-events:none}.trick-column{display:flex;flex-direction:column;align-items:center;flex:0 0 auto;min-width:var(--trick-card-w)}.trick-pile{position:relative;width:var(--trick-card-w);min-height:var(--trick-card-h)}.trick-pile--both{min-height:calc(var(--trick-card-h) * (2 - var(--trick-overlap)))}.trick-pile--you-only{min-height:var(--trick-card-h)}.trick-pile .trick-card{position:absolute;left:50%;transform:translate(-50%);z-index:1}.trick-pile .trick-card--rival{top:0;transform:translate(-50%) rotate(-4deg)}.trick-pile .trick-card--you{top:calc(var(--trick-card-h) * (1 - var(--trick-overlap)));transform:translate(-50%) rotate(4deg)}.trick-pile--rival-only .trick-card--rival,.trick-pile--you-only .trick-card--you{top:0}.trick-pile .trick-card--winner{z-index:3}.trick-pile .trick-card--loser{z-index:1}.trick-pile .trick-card--played-second:not(.trick-card--loser){z-index:2}.trick-pile .trick-card .playing-card:not(.on-table){filter:drop-shadow(0 5px 14px rgba(0,0,0,.48))}.trick-column.done{opacity:.88}.trick-column-label{font-size:.5rem;text-transform:uppercase;letter-spacing:.08em;color:#ffffff8c;text-shadow:0 1px 3px #000;margin-bottom:.15rem}.trick-column.current .trick-column-label{color:#fff0b4e6}.trick-pile .trick-card .playing-card,.trick-play-slot .playing-card,.trick-stack-slot .playing-card{--card-w: var(--trick-card-w);--card-h: var(--trick-card-h)}.trick-column.current .trick-pile .trick-card .playing-card,.trick-column.current .trick-play-slot .playing-card,.trick-column.current .trick-stack-slot .playing-card{--card-w: min(18vw, 82px);--card-h: calc(var(--card-w) * 1.46)}.trick-column.current{--trick-card-w: min(18vw, 82px);--trick-card-h: calc(min(18vw, 82px)*1.46) }.trick-pile--empty{min-height:0;width:0;margin:0;overflow:hidden;opacity:0}.trick-pile .playing-card.on-table[class*=skin-]:not(.face-down){background:transparent;border:none;box-shadow:none}.trick-pile .playing-card.on-table .card-face-img{object-fit:cover;border-radius:6px;box-shadow:0 5px 14px #0000007a}.turn-hint{position:absolute;bottom:8%;left:50%;transform:translate(-50%);margin:0;font-size:.7rem;color:#ffffffb3;text-shadow:0 1px 6px #000;white-space:nowrap}.hand-dock{position:relative;z-index:12;padding:0 .5rem .35rem;text-align:center}.game-screen .hand-dock{position:absolute;left:0;right:0;bottom:calc(var(--hand-dock-bottom) + env(safe-area-inset-bottom,0px) - 5%);margin-top:0;padding:.25rem .5rem 0;z-index:18;background:linear-gradient(0deg,rgba(0,0,0,.82),transparent 70%);transform:none;pointer-events:none}.game-screen .hand-dock .hand,.game-screen .hand-dock .hand-respond-bar{pointer-events:auto}.hand-play-hint{position:absolute;left:0;right:0;bottom:0;margin:0;font-size:.58rem;font-weight:600;letter-spacing:.04em;color:#f5d578d9;text-shadow:0 1px 4px #000;pointer-events:none}.game-screen .action-dock{position:absolute;left:0;right:0;bottom:0;z-index:20;padding:.2rem .45rem max(.35rem,env(safe-area-inset-bottom));background:linear-gradient(0deg,#000000e6,#00000080)}.game-screen .action-dock .action-dock-inner{gap:.2rem}.game-screen .action-dock .btn-canto-envido,.game-screen .action-dock .btn-canto-truco,.game-screen .action-dock .btn-mazo{padding:.28rem .45rem;font-size:.52rem;letter-spacing:.03em;border-radius:5px}.game-screen .hand-respond-bar .btn-respond-quiero,.game-screen .hand-respond-bar .btn-respond-no{font-size:.68rem;padding:.4rem .85rem}.hand--fan{display:flex;justify-content:center;align-items:flex-end;min-height:100px;padding:0 .5rem}.game-screen .hand--fan .playing-card{--card-w: 64px;--card-h: 94px}.game-screen .hand--fan{min-height:88px}.hand--fan .playing-card{--card-w: 76px;--card-h: 112px;margin-left:-22px;transform:rotate(var(--fan-rotate, 0deg));transform-origin:center bottom;transition:transform .15s ease,box-shadow .15s ease}.hand--fan .playing-card:first-child{margin-left:0}.hand--fan .playing-card.interactive:hover{transform:rotate(var(--fan-rotate, 0deg)) translateY(-10px);z-index:5}.hand--fan .playing-card.selected{transform:rotate(var(--fan-rotate, 0deg)) translateY(-18px);z-index:6;border-color:#f5d547;box-shadow:0 8px 28px #f5d54773}.action-dock{padding:.35rem .65rem .5rem;background:linear-gradient(0deg,rgba(0,0,0,.75),transparent);z-index:11}.game-screen .action-dock .action-group{gap:.25rem}.game-screen .action-dock .btn-primary.btn-large{padding:.35rem .75rem;font-size:.62rem;width:100%}.action-dock .btn-primary{background:linear-gradient(180deg,#5cb85c,#2d7a2d);color:#fff;box-shadow:0 2px 10px #00000059}.log-panel--game{max-height:4.5rem;margin:0 .65rem .5rem;padding:.4rem .65rem;background:#00000080;border-radius:8px;border-left:none;z-index:10}.log-panel--game .log-panel-title{color:#f0d878}.zone-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin:0 0 .5rem;text-shadow:0 1px 6px rgba(0,0,0,.85)}.opponent-zone{text-align:center}.card-back-stack{display:flex;justify-content:center;gap:0}.card-back-stack .playing-card{margin-left:-28px}.card-back-stack .playing-card:first-child{margin-left:0}.trick-zone{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:10px;transition:box-shadow .15s ease,background .15s ease}.trick-zone.drag-over{background:#00f0ff14;box-shadow:inset 0 0 0 2px #00f0ff66;border-radius:50%}.trick-meta{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:.75rem;font-size:.85rem;color:var(--text-muted)}.truco-badge,.pending-call{color:var(--accent);border:1px solid var(--border-glow);padding:.15rem .5rem;border-radius:4px}.table-cards{--card-w: 58px;--card-h: 86px;display:flex;justify-content:center;align-items:center;gap:.6rem;min-height:205px;width:100%}.table-trick-column{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem}.table-trick-column.current{--card-w: 70px;--card-h: 103px}.table-card-slot{width:var(--card-w);height:var(--card-h);display:grid;place-items:center}.table-card-slot:empty,.table-card-slot.drop-target:empty{border:1px dashed rgba(0,240,255,.2);border-radius:8px;background:#00000038}.table-card-slot.drop-target{border:1px dashed rgba(0,240,255,.2);border-radius:8px}.played-trick-label{font-size:.55rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.trick-slot{display:flex;flex-direction:column;align-items:center;gap:.35rem}.trick-player{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.hand-zone{text-align:center}.hand{display:flex;justify-content:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.playing-card{width:var(--card-w);height:var(--card-h);border-radius:8px;border:2px solid rgba(0,0,0,.15);background:var(--card-paper);color:var(--suit-black);display:block;padding:0;position:relative;overflow:hidden;flex-shrink:0}.playing-card[class*=skin-]:not(.face-down){background:#fff;border-color:#b8963a;box-shadow:2px 4px 12px #00000059;padding:0}.playing-card[class*=skin-].face-down{background:linear-gradient(145deg,#4a1818,#1a0808);border-color:#d4af37;padding:0;box-shadow:2px 4px 12px #00000073}.playing-card[class*=skin-].selected{border-color:#f0d060;box-shadow:0 0 20px #d4af378c}.card-face-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;object-position:center;border-radius:6px;display:block;pointer-events:none}.playing-card.face-down{background:linear-gradient(145deg,#4a1818,#1a0808);border-color:#c9a227;overflow:hidden}.card-back-art{position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:5px;border:1px solid rgba(212,175,55,.35);background:repeating-linear-gradient(45deg,rgba(212,175,55,.14) 0,rgba(212,175,55,.14) 3px,transparent 3px,transparent 7px),repeating-linear-gradient(-45deg,rgba(212,175,55,.1) 0,rgba(212,175,55,.1) 3px,transparent 3px,transparent 7px),radial-gradient(ellipse 70% 55% at 50% 50%,rgba(212,175,55,.12),transparent 70%)}.card-back-art:before{content:"";position:absolute;top:12%;right:12%;bottom:12%;left:12%;border:1px solid rgba(212,175,55,.25);border-radius:4px;pointer-events:none}.card-corner{position:absolute;display:flex;flex-direction:column;align-items:center;line-height:1;gap:1px}.card-corner-tl{top:4px;left:5px}.card-corner-br{bottom:4px;right:5px;transform:rotate(180deg)}.corner-rank{font-family:Rajdhani,sans-serif;font-weight:700;font-size:.85rem}.corner-glyph{width:14px;height:14px}.card-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.center-glyph{width:36px;height:36px}.center-glyph.figure{width:28px;height:28px}.figure-name{font-family:Rajdhani,sans-serif;font-weight:700;font-size:.55rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}.figure-suit{font-size:.5rem;text-transform:uppercase;letter-spacing:.1em;opacity:.75;margin-top:2px}.suit-glyph{display:block}.playing-card.interactive{cursor:pointer}.playing-card.draggable{cursor:grab;touch-action:none}.playing-card.draggable:active{cursor:grabbing}.playing-card.dragging{opacity:.45;transform:scale(.96)}.playing-card.interactive:hover,.playing-card.draggable.interactive:hover{transform:translateY(-6px)}.playing-card.selected{transform:translateY(-12px);box-shadow:0 0 24px #00f0ff80;border-color:var(--accent)}.action-bar{display:flex;flex-direction:column;gap:.75rem}.action-group{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.action-group-label{width:100%;font-size:.7rem;text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted)}.log-panel{font-size:.8rem;color:var(--text-muted);border-left:2px solid var(--border-glow);padding-left:.75rem;max-height:9rem;overflow-y:auto}.log-panel-title{margin:0 0 .35rem;font-size:.65rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent)}.log-empty{margin:0;font-style:italic;opacity:.75}.log-panel p{margin:.2rem 0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{background:var(--bg-panel);border:1px solid var(--accent);border-radius:var(--radius);padding:2rem;text-align:center;max-width:320px;box-shadow:0 0 60px #00f0ff33}.modal h2{font-family:Orbitron,sans-serif;margin:0 0 .5rem;color:var(--accent)}.modal .btn{margin:.5rem .25rem}.app-shell{max-width:520px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;background-color:#0d0806;background-image:linear-gradient(180deg,#050810d1,#050810eb),url(/bg/truco-royale-room.png?v=whatsapp-1);background-position:center top;background-size:100% auto;background-repeat:no-repeat}.app-shell-main{flex:1;overflow-y:auto;padding:0 .85rem 5.5rem}.app-header--compact .app-header-actions{display:none}.caja-intro{margin:0;font-size:.9rem;color:var(--text-muted);line-height:1.45}.caja-balance-panel{text-align:center;padding:1.25rem 1rem}.caja-balance-label{margin:0;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.caja-balance-value{margin:.35rem 0;font-family:Orbitron,sans-serif;font-size:2.25rem;color:#f5d547;display:flex;align-items:center;justify-content:center;gap:.35rem}.caja-balance-icon{font-size:1.5rem}.caja-balance-hint{margin:0;font-size:.8rem;color:var(--text-muted)}.caja-actions{display:flex;flex-direction:column;gap:.5rem}.caja-section-title{margin:0 0 .65rem;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.caja-admin-panel{margin-top:1rem}.caja-admin-form{display:flex;flex-direction:column;gap:.65rem}.caja-admin-success{margin:0;font-size:.85rem;color:var(--accent)}.torneo-new-pill{font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;padding:.2rem .45rem;border-radius:6px;background:#e53935;color:#fff;font-weight:700}.torneo-card-title{margin:.25rem 0 .35rem;font-size:1.05rem;color:#f0d878}.torneo-card-tag{margin:0;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}.torneo-card-meta{margin:0 0 .75rem;font-size:.85rem;color:var(--text-muted)}.torneo-card--highlight{border-color:#f5d54759}.jugar-mesas-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.jugar-mesas-head .mesas-section-title{margin:0}.perfil-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:.65rem 1rem;margin:0}.perfil-stats-grid div{display:flex;flex-direction:column;gap:.15rem}.perfil-stats-grid dt{margin:0;font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);font-weight:600}.perfil-stats-grid dd{margin:0;font-size:1.15rem;font-weight:700;color:#f0d878}.app-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.65rem .85rem;background:#00000073;border-bottom:1px solid rgba(212,175,55,.2)}.app-header-user{display:flex;align-items:center;gap:.5rem;min-width:0}.user-avatar{border-radius:50%;object-fit:cover;flex-shrink:0;background:linear-gradient(135deg,#d4af37,#8a6b12);color:#1a0808;display:flex;align-items:center;justify-content:center;font-weight:700}.user-avatar--sm{width:36px;height:36px;font-size:.95rem}.user-avatar--md{width:48px;height:48px;font-size:1.1rem}.user-avatar--lg{width:88px;height:88px;font-size:2rem;border:2px solid rgba(212,175,55,.45)}.app-header-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:7rem}.app-header-actions{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.coins-pill{display:flex;align-items:center;gap:.25rem;padding:.35rem .65rem;border-radius:999px;border:1px solid rgba(212,175,55,.5);background:#00000080;color:#f5d547;font-weight:700;cursor:default}.coins-pill-icon{color:#f5d547;font-size:.85rem}.whatsapp-actions{display:flex;gap:.2rem}.btn-whatsapp{font-size:.65rem;padding:.35rem .45rem;letter-spacing:.04em;border-radius:6px}.btn-whatsapp--carga{background:#25d366;color:#fff}.btn-whatsapp--retiro{background:#ffffff1f;color:var(--text);border:1px solid rgba(255,255,255,.2)}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:520px;display:flex;justify-content:space-around;align-items:flex-end;padding:.35rem .25rem calc(.35rem + env(safe-area-inset-bottom,0));background:linear-gradient(180deg,#080c18f2,#04060efa);border-top:1px solid rgba(0,240,255,.2);z-index:50}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.35rem .15rem;border:none;background:transparent;color:var(--text-muted);font-family:inherit;font-size:.62rem;letter-spacing:.06em;text-transform:uppercase;cursor:pointer}.bottom-nav-item--active{color:var(--accent)}.bottom-nav-icon-wrap{position:relative;display:inline-flex}.bottom-nav-badge{position:absolute;top:-2px;right:-4px;width:8px;height:8px;border-radius:50%;background:#e53935;border:1.5px solid #1a1020;box-shadow:0 0 6px #e53935cc}.bottom-nav-item--center .bottom-nav-icon{font-size:1.5rem;margin-top:-.65rem;background:linear-gradient(180deg,#f5d547,#c9a020);border-radius:50%;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #f5d54759}.bottom-nav-icon{font-size:1.1rem;line-height:1}.tab-screen{display:flex;flex-direction:column;gap:.85rem}.tab-title{font-family:Orbitron,sans-serif;font-size:1.1rem;margin:0;color:#f0d878;letter-spacing:.08em}.mesas-toolbar{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding-top:.5rem}.mode-badge{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;padding:.25rem .5rem;border-radius:6px;border:1px solid rgba(0,240,255,.45);color:var(--accent);background:#00f0ff1a}.mesas-intro{margin:0;font-size:.9rem;line-height:1.45;color:var(--text-muted)}.mesas-setup-panel{display:flex;flex-direction:column;gap:.75rem}.mesas-play-btn{margin-top:.25rem}.mesas-back{padding:0}.mesas-section-title{margin:0 0 .5rem;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.mesa-waiting-panel{display:flex;flex-direction:column;gap:.35rem}.mesa-waiting-title{margin:0;font-weight:700;color:#f0d878}.mesa-waiting-meta{margin:0;font-size:.9rem}.mesa-notice{margin:0}.link-btn{border:none;background:none;color:var(--accent);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer}.mesas-actions{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.mesas-action{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;min-height:4.5rem;border:none;border-radius:10px;font-family:Orbitron,sans-serif;font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;color:#001018}.mesas-action--play{background:linear-gradient(180deg,#6eb8ff,#2a6eb8)}.mesas-action--create{background:linear-gradient(180deg,#f5d547,#c9a020)}.mesas-action-sub{font-size:.65rem;opacity:.85;font-family:Rajdhani,sans-serif;text-transform:none}.table-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.table-card{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.65rem .75rem;background:#0006;border:1px solid rgba(255,255,255,.08);border-radius:10px}.table-card-head{display:flex;align-items:center;gap:.5rem;min-width:0}.table-card-avatar{width:40px;height:40px;border-radius:8px;background:#7b2fff59;display:flex;align-items:center;justify-content:center;font-weight:700}.table-card-host{margin:0;font-weight:600}.table-card-meta{margin:.1rem 0 0;font-size:.75rem;color:var(--text-muted)}.btn-table-join{flex-shrink:0;padding:.45rem .85rem;border:none;border-radius:8px;background:#fff;color:#1a1020;font-weight:700;font-size:.75rem;letter-spacing:.06em;cursor:pointer}.placeholder-screen,.ranking-screen,.perfil-screen{padding-top:.5rem}.placeholder-text{color:var(--text-muted);margin:0;line-height:1.45}.ranking-list{list-style:none;margin:0;padding:0}.ranking-row{display:flex;align-items:center;gap:.5rem;padding:.55rem .65rem;background:#00000059;border-radius:8px;margin-bottom:.35rem}.ranking-body{flex:1;display:flex;flex-direction:column;gap:.1rem;min-width:0}.ranking-detail{font-size:.72rem;color:var(--text-muted);letter-spacing:.02em}.modal-stake-note{margin:.35rem 0 .75rem;font-size:.85rem;color:var(--accent)}.modal-rematch{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem}.modal-rematch-hint{margin:0;font-size:.75rem;color:var(--text-muted)}.ranking-pos{width:1.5rem;color:#f5d547;font-weight:700}.ranking-name{flex:1}.ranking-pts{color:var(--text-muted);font-size:.85rem}.perfil-card .perfil-label{margin:.5rem 0 .15rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.perfil-card .perfil-label:first-child{margin-top:0}.perfil-value{margin:0;font-size:1.05rem}.perfil-coins{color:#f5d547;font-weight:700}.perfil-photo-section{display:flex;flex-direction:column;gap:.5rem}.perfil-photo-row{display:flex;align-items:center;gap:1rem}.perfil-photo-actions{display:flex;flex-direction:column;gap:.4rem;flex:1}.perfil-file-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.perfil-photo-hint{margin:0;font-size:.75rem;color:var(--text-muted)}.perfil-remove-photo{font-size:.8rem;padding:.35rem .5rem}.auth-screen{justify-content:center}.hero--compact h1{font-size:2rem}.auth-form{display:flex;flex-direction:column;gap:.75rem}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:.35rem}.auth-tab{padding:.5rem;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:transparent;color:var(--text-muted);font-family:inherit;cursor:pointer}.auth-tab--active{border-color:var(--accent);color:var(--accent);background:#00f0ff14}.auth-register-intro{margin:0;font-size:.85rem;color:var(--text-muted);line-height:1.4}.field--auth .field-hint{margin-top:.2rem}.field input,.field select{width:100%;margin-top:.25rem;padding:.55rem .65rem;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:#00000059;color:var(--text);font-family:inherit;font-size:1rem}.auth-error{color:var(--danger);margin:0;font-size:.9rem}.auth-hint{margin:0;font-size:.75rem;color:var(--text-muted);line-height:1.4}.game-screen .game-round-hint{position:absolute;left:50%;bottom:calc(5.5rem + env(safe-area-inset-bottom,0px));transform:translate(-50%);z-index:19;margin:0;font-size:.75rem;color:#ffffffbf;text-shadow:0 1px 6px #000;pointer-events:none}.game-screen--loading{align-items:center;justify-content:center}.game-loading{color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase}
