@import"https://fonts.googleapis.com/css2?family=Russo+One&family=Chakra+Petch:wght@400;500;600;700&display=swap";:root{--pp-primary: #7C3AED;--pp-primary-light: #A78BFA;--pp-primary-dark: #6D28D9;--pp-accent: #F43F5E;--game-accent: #7C3AED;--game-accent-light: #A78BFA;--game-accent-dark: #6D28D9;--game-accent-rgb: 124, 58, 237;--pp-bg-deep: #0a0a14;--pp-bg-dark: #0F0F23;--pp-bg-surface: #1A1A2E;--pp-bg-surface-light: #252547;--pp-surface-1: rgba(255, 255, 255, .03);--pp-surface-2: rgba(255, 255, 255, .05);--pp-surface-3: rgba(255, 255, 255, .08);--pp-surface-4: rgba(255, 255, 255, .12);--pp-border-subtle: rgba(255, 255, 255, .06);--pp-border-light: rgba(255, 255, 255, .1);--pp-border-medium: rgba(255, 255, 255, .15);--pp-text: #E2E8F0;--pp-text-secondary: #CBD5E1;--pp-text-muted: #94A3B8;--pp-text-dim: #64748B;--pp-success: #22C55E;--pp-success-bg: rgba(34, 197, 94, .15);--pp-warning: #FBBF24;--pp-warning-bg: rgba(251, 191, 36, .15);--pp-error: #F43F5E;--pp-error-bg: rgba(244, 63, 94, .15);--pp-font-heading: "Russo One", sans-serif;--pp-font-body: "Chakra Petch", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--pp-font-mono: "JetBrains Mono", "Courier New", monospace;--pp-text-xs: 11px;--pp-text-sm: 13px;--pp-text-base: 15px;--pp-text-lg: 18px;--pp-text-xl: 22px;--pp-text-2xl: 28px;--pp-text-3xl: 36px;--pp-text-4xl: 48px;--pp-space-xs: 4px;--pp-space-sm: 8px;--pp-space-md: 16px;--pp-space-lg: 24px;--pp-space-xl: 32px;--pp-space-2xl: 48px;--pp-radius-sm: 8px;--pp-radius-md: 12px;--pp-radius-lg: 16px;--pp-radius-xl: 24px;--pp-radius-full: 50%;--pp-shadow-sm: 0 2px 8px rgba(0, 0, 0, .2);--pp-shadow-md: 0 4px 16px rgba(0, 0, 0, .3);--pp-shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--pp-shadow-glow: 0 0 20px rgba(var(--game-accent-rgb), .3);--pp-transition-fast: .1s ease;--pp-transition-normal: .2s ease;--pp-transition-slow: .3s ease-out}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--pp-font-body);background:linear-gradient(180deg,var(--pp-bg-surface) 0%,var(--pp-bg-deep) 100%);color:var(--pp-text);line-height:1.5}#app{width:100%;height:100%;overflow:hidden}a{color:var(--game-accent);text-decoration:none}strong{font-weight:600}.pp-app{width:100%;height:100%;overflow:hidden;position:relative}.pp-loading,.pp-error{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;gap:var(--pp-space-md)}.pp-spinner{width:48px;height:48px;border:4px solid rgba(var(--game-accent-rgb),.2);border-top-color:var(--game-accent);border-radius:50%;animation:pp-spin 1s linear infinite}@keyframes pp-spin{to{transform:rotate(360deg)}}.pp-error-title{color:var(--pp-error);font-family:var(--pp-font-heading);font-size:var(--pp-text-xl)}.pp-error-message{color:var(--pp-text-muted);font-size:var(--pp-text-sm)}.pp-header{display:flex;align-items:center;justify-content:space-between;padding:var(--pp-space-md);background:var(--pp-surface-1);border-radius:var(--pp-radius-md);border:1px solid var(--pp-border-subtle);flex-shrink:0}.pp-header-left,.pp-header-right{display:flex;align-items:center;gap:var(--pp-space-sm)}.pp-header-center{display:flex;flex-direction:column;align-items:center;gap:2px}.pp-game-title{font-family:var(--pp-font-heading);font-size:var(--pp-text-base);color:var(--game-accent);letter-spacing:2px;display:flex;align-items:center;gap:var(--pp-space-sm)}.pp-game-subtitle{font-size:var(--pp-text-sm);color:var(--pp-text-muted)}.pp-badge{font-size:var(--pp-text-xs);padding:2px 8px;border-radius:var(--pp-radius-sm);font-weight:600;white-space:nowrap;display:inline-flex;align-items:center;gap:4px}.pp-badge--accent{background:rgba(var(--game-accent-rgb),.15);color:var(--game-accent);border:1px solid rgba(var(--game-accent-rgb),.3)}.pp-badge--success{background:var(--pp-success-bg);color:var(--pp-success)}.pp-badge--warning{background:var(--pp-warning-bg);color:var(--pp-warning)}.pp-badge--error{background:var(--pp-error-bg);color:var(--pp-error)}.pp-badge--muted{background:#ffffff0f;color:var(--pp-text-dim)}.pp-avatar{border-radius:var(--pp-radius-full);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;flex-shrink:0;text-transform:uppercase}.pp-avatar--sm{width:24px;height:24px;font-size:11px}.pp-avatar--md{width:36px;height:36px;font-size:15px}.pp-avatar--lg{width:44px;height:44px;font-size:20px}.pp-player-card{padding:var(--pp-space-md);background:var(--pp-surface-2);border-radius:var(--pp-radius-md);border:2px solid transparent;transition:border-color var(--pp-transition-normal),background var(--pp-transition-normal)}.pp-player-card--active{border-color:rgba(var(--game-accent-rgb),.5);background:rgba(var(--game-accent-rgb),.06)}.pp-player-card--eliminated{opacity:.4}.pp-player-row{display:flex;align-items:center;gap:var(--pp-space-md);padding:10px var(--pp-space-md);background:var(--pp-surface-2);border-radius:var(--pp-radius-sm);border:1px solid var(--pp-border-subtle);transition:all var(--pp-transition-normal)}.pp-player-row--active{border-color:rgba(var(--game-accent-rgb),.4);background:rgba(var(--game-accent-rgb),.06)}.pp-player-row--eliminated{opacity:.4}.pp-player-name{font-size:var(--pp-text-sm);font-weight:600;color:var(--pp-text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pp-player-dot{width:12px;height:12px;border-radius:var(--pp-radius-full);display:inline-block;flex-shrink:0}.pp-card{width:64px;height:88px;border-radius:var(--pp-radius-sm);border:2px solid var(--pp-border-light);background:var(--pp-surface-2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transition:all var(--pp-transition-normal)}.pp-card--empty{border-style:dashed;opacity:.3}.pp-card--winner{box-shadow:0 0 16px #ffdc3299;border-color:#ffd732}.pp-card-number{font-family:var(--pp-font-heading);font-size:var(--pp-text-lg);color:var(--pp-text)}.pp-card-badge{padding:2px 8px;border-radius:6px;font-size:var(--pp-text-xs);font-weight:600}.pp-card-badge--hidden{background:var(--pp-surface-3);color:var(--pp-text-dim)}.pp-card-badge--revealed{background:var(--pp-error-bg);color:#f99;border:1px solid rgba(255,100,100,.4)}.pp-panel{padding:var(--pp-space-md);background:var(--pp-surface-1);border-radius:var(--pp-radius-lg);border:1px solid var(--pp-border-subtle)}.pp-btn{padding:14px 40px;font-family:var(--pp-font-body);font-size:var(--pp-text-base);font-weight:700;border:none;border-radius:var(--pp-radius-md);cursor:pointer;transition:all var(--pp-transition-normal);display:inline-flex;align-items:center;justify-content:center;gap:var(--pp-space-sm)}.pp-btn--primary{background:linear-gradient(135deg,var(--game-accent) 0%,var(--game-accent-dark) 100%);color:var(--pp-bg-dark)}.pp-btn--primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px rgba(var(--game-accent-rgb),.35)}.pp-btn--secondary{background:var(--pp-surface-3);color:var(--pp-text-muted);border:1px solid var(--pp-border-light)}.pp-btn--secondary:hover:not(:disabled){background:var(--pp-surface-4);color:var(--pp-text)}.pp-btn:disabled{background:var(--pp-bg-surface);color:var(--pp-text-dim);cursor:not-allowed;transform:none;box-shadow:none}.pp-lobby{display:flex;flex-direction:column;align-items:center;gap:var(--pp-space-lg);padding:40px;max-width:700px;margin:0 auto;height:100%;overflow:auto}.pp-lobby-header{text-align:center}.pp-lobby-title{font-family:var(--pp-font-heading);font-size:var(--pp-text-3xl);color:var(--game-accent);letter-spacing:6px;margin:var(--pp-space-sm) 0 0}.pp-lobby-subtitle{font-size:var(--pp-text-sm);color:var(--pp-text-muted);letter-spacing:2px;margin:4px 0 0}.pp-qr-section{display:flex;flex-direction:column;align-items:center;gap:var(--pp-space-md);padding:var(--pp-space-lg);background:var(--pp-surface-2);border-radius:var(--pp-radius-lg);border:1px solid rgba(var(--game-accent-rgb),.2)}.pp-qr-container{padding:var(--pp-space-md);background:#fff;border-radius:var(--pp-radius-sm)}.pp-qr-container img{width:140px;height:140px;display:block}.pp-pin-label{font-size:var(--pp-text-xs);color:var(--pp-text-muted);text-transform:uppercase;letter-spacing:2px}.pp-pin-code{font-family:var(--pp-font-mono);font-size:var(--pp-text-2xl);font-weight:700;color:var(--pp-text);letter-spacing:6px}.pp-join-instruction{font-size:var(--pp-text-sm);color:var(--pp-text-dim)}.pp-player-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.pp-player-list{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.pp-section-title{font-size:var(--pp-text-sm);color:var(--pp-text-muted);text-transform:uppercase;letter-spacing:2px;text-align:center;margin:0 0 var(--pp-space-md)}.pp-rank-card{display:flex;align-items:center;gap:var(--pp-space-md);padding:var(--pp-space-md) 20px;border-radius:var(--pp-radius-md);background:var(--pp-surface-2);border:2px solid var(--pp-border-light);transition:transform var(--pp-transition-normal)}.pp-rank-card--winner{background:rgba(var(--game-accent-rgb),.08);animation:pp-winner-glow 2s ease-in-out infinite}@keyframes pp-winner-glow{0%,to{box-shadow:0 0 rgba(var(--game-accent-rgb),.2)}50%{box-shadow:0 0 24px rgba(var(--game-accent-rgb),.35)}}.pp-rank-num{font-family:var(--pp-font-heading);font-size:var(--pp-text-xl);min-width:40px;text-align:center;color:var(--pp-text-muted)}.pp-rank-num--1{color:gold}.pp-rank-num--2{color:silver}.pp-rank-num--3{color:#cd7f32}.pp-rank-details{flex:1;display:flex;align-items:center;gap:var(--pp-space-md)}.pp-rank-name{font-size:var(--pp-text-base);font-weight:600;color:var(--pp-text)}.pp-rank-score{font-family:var(--pp-font-heading);font-size:var(--pp-text-xl);font-weight:700}.pp-winner-label{font-size:var(--pp-text-xs);color:var(--game-accent);background:rgba(var(--game-accent-rgb),.15);padding:2px 8px;border-radius:var(--pp-radius-sm)}.pp-log{position:fixed;bottom:10px;left:10px;right:10px;max-height:150px;overflow-y:auto;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:10px;border-radius:var(--pp-radius-sm);font-size:var(--pp-text-xs);font-family:var(--pp-font-mono)}.pp-log p{margin:2px 0;color:var(--pp-text-muted)}.pp-timer{font-family:var(--pp-font-heading);font-size:var(--pp-text-lg);color:var(--pp-warning)}.pp-action-panel{padding:10px var(--pp-space-md);background:var(--pp-warning-bg);border:1px solid rgba(251,191,36,.3);border-radius:var(--pp-radius-sm);font-size:var(--pp-text-sm);color:var(--pp-text)}.pp-coins{font-size:var(--pp-text-sm);color:var(--pp-warning);display:inline-flex;align-items:center;gap:4px}.pp-table{width:100%;border-collapse:collapse;font-size:var(--pp-text-xs)}.pp-table thead th{padding:6px 8px;text-align:center;background:var(--pp-surface-2);font-size:var(--pp-text-xs);font-weight:600;color:var(--pp-text-muted);border-bottom:1px solid var(--pp-border-subtle)}.pp-table tbody td{padding:5px 8px;border-bottom:1px solid var(--pp-border-subtle)}.pp-table tbody tr:hover{background:var(--pp-surface-1)}.pp-game-over{display:flex;flex-direction:column;align-items:center;gap:var(--pp-space-lg);padding:40px;height:100%;overflow:auto}.pp-game-over-title{font-family:var(--pp-font-heading);font-size:var(--pp-text-3xl);color:var(--game-accent)}.pp-game-over-subtitle{font-size:var(--pp-text-base);color:var(--pp-text-muted)}.pp-result-screen{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.pp-result-content{display:flex;flex-direction:column;align-items:center;gap:var(--pp-space-lg);padding:var(--pp-space-2xl);background:var(--pp-bg-surface);border-radius:20px;border:1px solid var(--pp-border-light);max-width:500px;width:90%}.pp-result-title{font-family:var(--pp-font-heading);font-size:var(--pp-text-3xl);text-align:center}.pp-result-title--success{color:var(--pp-success)}.pp-result-title--fail{color:var(--pp-error)}.pp-suit-dot{width:16px;height:16px;border-radius:var(--pp-radius-full);background:var(--suit-color);display:inline-block;box-shadow:0 0 6px var(--suit-color);vertical-align:middle}.pp-suit-dot--lg{width:24px;height:24px}.pp-die{width:40px;height:40px;background:var(--pp-surface-3);border:2px solid var(--pp-border-light);border-radius:6px;display:flex;align-items:center;justify-content:center;font-family:var(--pp-font-heading);font-size:var(--pp-text-xl);color:var(--pp-text);transition:all var(--pp-transition-normal);position:relative}.pp-die--kept{border-color:var(--game-accent);background:rgba(var(--game-accent-rgb),.12)}.pp-die-kept-label{position:absolute;bottom:-2px;font-size:7px;color:var(--game-accent);text-transform:uppercase;font-family:var(--pp-font-body);font-weight:600;letter-spacing:.5px}.pp-mission-row{display:flex;align-items:center;gap:var(--pp-space-md);padding:10px 14px;background:var(--pp-surface-1);border-radius:var(--pp-radius-sm);border-left:3px solid var(--pp-text-dim)}.pp-mission-row--success{border-left-color:var(--pp-success)}.pp-mission-row--fail{border-left-color:var(--pp-error)}.pp-icon{display:inline-block;width:1em;height:1em;vertical-align:-.125em;background:currentColor;mask-size:contain;mask-repeat:no-repeat;mask-position:center;-webkit-mask-size:contain;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center}.pp-icon--sm{width:14px;height:14px}.pp-icon--md{width:20px;height:20px}.pp-icon--lg{width:28px;height:28px}.pp-icon--xl{width:40px;height:40px}.pp-icon-trophy{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9H4.5a2.5 2.5 0 0 1 0-5H6'/%3E%3Cpath d='M18 9h1.5a2.5 2.5 0 0 0 0-5H18'/%3E%3Cpath d='M4 22h16'/%3E%3Cpath d='M10 14.66V17c0 .55-.47.98-.97 1.21C7.85 18.75 7 20.24 7 22'/%3E%3Cpath d='M14 14.66V17c0 .55.47.98.97 1.21C16.15 18.75 17 20.24 17 22'/%3E%3Cpath d='M18 2H6v7a6 6 0 0 0 12 0V2Z'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9H4.5a2.5 2.5 0 0 1 0-5H6'/%3E%3Cpath d='M18 9h1.5a2.5 2.5 0 0 0 0-5H18'/%3E%3Cpath d='M4 22h16'/%3E%3Cpath d='M10 14.66V17c0 .55-.47.98-.97 1.21C7.85 18.75 7 20.24 7 22'/%3E%3Cpath d='M14 14.66V17c0 .55.47.98.97 1.21C16.15 18.75 17 20.24 17 22'/%3E%3Cpath d='M18 2H6v7a6 6 0 0 0 12 0V2Z'/%3E%3C/svg%3E")}.pp-icon-coin{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='M16 8h-6a2 2 0 1 0 0 4h4a2 2 0 1 1 0 4H8'/%3E%3Cpath d='M12 18V6'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='M16 8h-6a2 2 0 1 0 0 4h4a2 2 0 1 1 0 4H8'/%3E%3Cpath d='M12 18V6'/%3E%3C/svg%3E")}.pp-icon-skull{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='12' r='1'/%3E%3Ccircle cx='15' cy='12' r='1'/%3E%3Cpath d='M8 20v2h8v-2'/%3E%3Cpath d='m12.5 17-.5-1-.5 1h1z'/%3E%3Cpath d='M16 20a2 2 0 0 0 1.56-3.25 8 8 0 1 0-11.12 0A2 2 0 0 0 8 20'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='12' r='1'/%3E%3Ccircle cx='15' cy='12' r='1'/%3E%3Cpath d='M8 20v2h8v-2'/%3E%3Cpath d='m12.5 17-.5-1-.5 1h1z'/%3E%3Cpath d='M16 20a2 2 0 0 0 1.56-3.25 8 8 0 1 0-11.12 0A2 2 0 0 0 8 20'/%3E%3C/svg%3E")}.pp-icon-shield{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 13c0 5-3.5 7.5-7.66 8.95a1 1 0 0 1-.67-.01C7.5 20.5 4 18 4 13V6a1 1 0 0 1 1-1c2 0 4.5-1.2 6.24-2.72a1.17 1.17 0 0 1 1.52 0C14.51 3.81 17 5 19 5a1 1 0 0 1 1 1z'/%3E%3Cpath d='m9 12 2 2 4-4'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 13c0 5-3.5 7.5-7.66 8.95a1 1 0 0 1-.67-.01C7.5 20.5 4 18 4 13V6a1 1 0 0 1 1-1c2 0 4.5-1.2 6.24-2.72a1.17 1.17 0 0 1 1.52 0C14.51 3.81 17 5 19 5a1 1 0 0 1 1 1z'/%3E%3Cpath d='m9 12 2 2 4-4'/%3E%3C/svg%3E")}.pp-icon-crown{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M11.562 3.266a.5.5 0 0 1 .876 0L15.39 8.87a1 1 0 0 0 1.516.294L21.183 5.5a.5.5 0 0 1 .798.519l-2.834 10.246a1 1 0 0 1-.956.734H5.81a1 1 0 0 1-.957-.734L2.02 6.02a.5.5 0 0 1 .798-.519l4.276 3.664a1 1 0 0 0 1.516-.294z'/%3E%3Cpath d='M5 21h14'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M11.562 3.266a.5.5 0 0 1 .876 0L15.39 8.87a1 1 0 0 0 1.516.294L21.183 5.5a.5.5 0 0 1 .798.519l-2.834 10.246a1 1 0 0 1-.956.734H5.81a1 1 0 0 1-.957-.734L2.02 6.02a.5.5 0 0 1 .798-.519l4.276 3.664a1 1 0 0 0 1.516-.294z'/%3E%3Cpath d='M5 21h14'/%3E%3C/svg%3E")}.pp-icon-check{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E")}.pp-icon-timer{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpolyline points='12 6 12 12 16 14'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpolyline points='12 6 12 12 16 14'/%3E%3C/svg%3E")}.pp-icon-letter{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='20' height='16' x='2' y='4' rx='2'/%3E%3Cpath d='m22 7-8.97 5.7a1.94 1.94 0 0 1-2.06 0L2 7'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='20' height='16' x='2' y='4' rx='2'/%3E%3Cpath d='m22 7-8.97 5.7a1.94 1.94 0 0 1-2.06 0L2 7'/%3E%3C/svg%3E")}.pp-icon-masks{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M2 12a5 5 0 0 0 5 5 8 8 0 0 1 5 2 8 8 0 0 1 5-2 5 5 0 0 0 5-5V7h-5a8 8 0 0 0-5 2 8 8 0 0 0-5-2H2Z'/%3E%3Cpath d='M6 11c1.5 0 3 .5 3 2-2 0-3 0-3-2Z'/%3E%3Cpath d='M18 11c-1.5 0-3 .5-3 2 2 0 3 0 3-2Z'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M2 12a5 5 0 0 0 5 5 8 8 0 0 1 5 2 8 8 0 0 1 5-2 5 5 0 0 0 5-5V7h-5a8 8 0 0 0-5 2 8 8 0 0 0-5-2H2Z'/%3E%3Cpath d='M6 11c1.5 0 3 .5 3 2-2 0-3 0-3-2Z'/%3E%3Cpath d='M18 11c-1.5 0-3 .5-3 2 2 0 3 0 3-2Z'/%3E%3C/svg%3E")}.pp-icon-rocket{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4.5 16.5c-1.5 1.26-2 5-2 5s3.74-.5 5-2c.71-.84.7-2.13-.09-2.91a2.18 2.18 0 0 0-2.91-.09z'/%3E%3Cpath d='m12 15-3-3a22 22 0 0 1 2-3.95A12.88 12.88 0 0 1 22 2c0 2.72-.78 7.5-6 11a22.35 22.35 0 0 1-4 2z'/%3E%3Cpath d='M9 12H4s.55-3.03 2-4c1.62-1.08 5 0 5 0'/%3E%3Cpath d='M12 15v5s3.03-.55 4-2c1.08-1.62 0-5 0-5'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4.5 16.5c-1.5 1.26-2 5-2 5s3.74-.5 5-2c.71-.84.7-2.13-.09-2.91a2.18 2.18 0 0 0-2.91-.09z'/%3E%3Cpath d='m12 15-3-3a22 22 0 0 1 2-3.95A12.88 12.88 0 0 1 22 2c0 2.72-.78 7.5-6 11a22.35 22.35 0 0 1-4 2z'/%3E%3Cpath d='M9 12H4s.55-3.03 2-4c1.62-1.08 5 0 5 0'/%3E%3Cpath d='M12 15v5s3.03-.55 4-2c1.08-1.62 0-5 0-5'/%3E%3C/svg%3E")}.pp-icon-dice{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='18' height='18' x='3' y='3' rx='2' ry='2'/%3E%3Cpath d='M16 8h.01'/%3E%3Cpath d='M12 12h.01'/%3E%3Cpath d='M8 16h.01'/%3E%3Cpath d='M16 16h.01'/%3E%3Cpath d='M8 8h.01'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='18' height='18' x='3' y='3' rx='2' ry='2'/%3E%3Cpath d='M16 8h.01'/%3E%3Cpath d='M12 12h.01'/%3E%3Cpath d='M8 16h.01'/%3E%3Cpath d='M16 16h.01'/%3E%3Cpath d='M8 8h.01'/%3E%3C/svg%3E")}.pp-icon-cards{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 8a2 2 0 0 0-1-1.73l-7-4a2 2 0 0 0-2 0l-7 4A2 2 0 0 0 3 8v8a2 2 0 0 0 1 1.73l7 4a2 2 0 0 0 2 0l7-4A2 2 0 0 0 21 16Z'/%3E%3Cpath d='m3.3 7 8.7 5 8.7-5'/%3E%3Cpath d='M12 22V12'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 8a2 2 0 0 0-1-1.73l-7-4a2 2 0 0 0-2 0l-7 4A2 2 0 0 0 3 8v8a2 2 0 0 0 1 1.73l7 4a2 2 0 0 0 2 0l7-4A2 2 0 0 0 21 16Z'/%3E%3Cpath d='m3.3 7 8.7 5 8.7-5'/%3E%3Cpath d='M12 22V12'/%3E%3C/svg%3E")}.pp-icon-comm{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4.9 19.1C1 15.2 1 8.8 4.9 4.9'/%3E%3Cpath d='M7.8 16.2c-2.3-2.3-2.3-6.1 0-8.4'/%3E%3Ccircle cx='12' cy='12' r='2'/%3E%3Cpath d='M16.2 7.8c2.3 2.3 2.3 6.1 0 8.4'/%3E%3Cpath d='M19.1 4.9C23 8.8 23 15.1 19.1 19'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4.9 19.1C1 15.2 1 8.8 4.9 4.9'/%3E%3Cpath d='M7.8 16.2c-2.3-2.3-2.3-6.1 0-8.4'/%3E%3Ccircle cx='12' cy='12' r='2'/%3E%3Cpath d='M16.2 7.8c2.3 2.3 2.3 6.1 0 8.4'/%3E%3Cpath d='M19.1 4.9C23 8.8 23 15.1 19.1 19'/%3E%3C/svg%3E")}.pp-icon-hourglass{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 22h14'/%3E%3Cpath d='M5 2h14'/%3E%3Cpath d='M17 22v-4.172a2 2 0 0 0-.586-1.414L12 12l-4.414 4.414A2 2 0 0 0 7 17.828V22'/%3E%3Cpath d='M7 2v4.172a2 2 0 0 0 .586 1.414L12 12l4.414-4.414A2 2 0 0 0 17 6.172V2'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 22h14'/%3E%3Cpath d='M5 2h14'/%3E%3Cpath d='M17 22v-4.172a2 2 0 0 0-.586-1.414L12 12l-4.414 4.414A2 2 0 0 0 7 17.828V22'/%3E%3Cpath d='M7 2v4.172a2 2 0 0 0 .586 1.414L12 12l4.414-4.414A2 2 0 0 0 17 6.172V2'/%3E%3C/svg%3E")}.pp-fade-in{animation:pp-fadeIn .3s ease}@keyframes pp-fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.pp-slide-up{animation:pp-slideUp .4s ease-out}@keyframes pp-slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.pp-anim-card-play{animation:pp-cardPlay .3s ease}@keyframes pp-cardPlay{0%{transform:scale(.85) translateY(16px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.pp-anim-celebrate{width:72px;height:72px;border-radius:50%;background:radial-gradient(circle,var(--pp-success) 0%,transparent 70%);animation:pp-celebrate 1.5s ease-in-out infinite}@keyframes pp-celebrate{0%,to{transform:scale(1);opacity:.7}50%{transform:scale(1.15);opacity:1}}.pp-anim-sparkle{width:72px;height:72px;border-radius:50%;background:radial-gradient(circle,var(--game-accent) 0%,transparent 70%);animation:pp-sparkle 1.2s ease-in-out infinite}@keyframes pp-sparkle{0%,to{transform:scale(1) rotate(0);opacity:.6}50%{transform:scale(1.2) rotate(10deg);opacity:1}}.pp-anim-fail{width:72px;height:72px;border-radius:50%;background:radial-gradient(circle,var(--pp-error) 0%,transparent 70%);animation:pp-fail .8s ease-in-out}@keyframes pp-fail{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.1);opacity:1}to{transform:scale(1);opacity:.7}}.pp-anim-timer-pulse{animation:pp-timerPulse 1s ease-in-out infinite}@keyframes pp-timerPulse{0%,to{opacity:1}50%{opacity:.5}}.pp-rank-medal{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--pp-font-heading);font-size:14px;font-weight:700}.pp-rank-medal--1{background:linear-gradient(135deg,gold,orange);color:#1a1a2e;box-shadow:0 0 12px #ffd70066}.pp-rank-medal--2{background:linear-gradient(135deg,#e0e0e0,#a0a0a0);color:#1a1a2e}.pp-rank-medal--3{background:linear-gradient(135deg,#cd7f32,#a0622e);color:#fff}.pp-rank-medal--other{background:var(--pp-surface-3);color:var(--pp-text-muted)}@media(prefers-reduced-motion:reduce){.pp-fade-in,.pp-slide-up,.pp-anim-card-play{animation:none}.pp-anim-celebrate,.pp-anim-sparkle,.pp-anim-fail,.pp-anim-timer-pulse,.pp-spinner{animation-duration:0s}.pp-rank-card--winner{animation:none;box-shadow:0 0 12px rgba(var(--game-accent-rgb),.3)}}
