.auth-page{min-height:calc(100vh - var(--navbar-height));display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.auth-container{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-2xl);animation:slideUp .5s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:var(--spacing-xl)}.auth-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.auth-header h1{margin-bottom:var(--spacing-xs);font-size:1.75rem}.auth-header p{color:var(--text-secondary);font-size:.95rem}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.auth-error{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:#ef4444;font-size:.875rem;animation:shake .5s ease}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-5px)}40%,80%{transform:translate(5px)}}.error-icon{flex-shrink:0}.auth-success{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#22c55e26;border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-md);color:#22c55e;font-size:.875rem}.btn-large{padding:var(--spacing-md) var(--spacing-xl);font-size:1rem}.auth-footer{margin-top:var(--spacing-xl);text-align:center;padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.auth-divider{display:flex;align-items:center;gap:var(--spacing-md);margin:var(--spacing-lg) 0;color:var(--text-secondary);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.google-signin-wrapper{display:flex;justify-content:center}.auth-footer p{color:var(--text-secondary);font-size:.875rem}.auth-footer a{color:var(--primary-light);font-weight:600}.auth-footer a:hover{text-decoration:underline}@media(max-width:480px){.auth-page{padding:var(--spacing-md)}.auth-container{padding:var(--spacing-lg)}}.upload-page{min-height:calc(100vh - var(--navbar-height));padding:var(--spacing-xl);background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.upload-container{max-width:640px;margin:0 auto;animation:fadeIn .5s ease}.upload-header{text-align:center;margin-bottom:var(--spacing-xl)}.upload-header h1{margin-bottom:var(--spacing-sm)}.upload-header p{color:var(--text-secondary);font-size:1.125rem}.upload-form{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-xl);display:flex;flex-direction:column;gap:var(--spacing-xl)}.upload-message{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md);border-radius:var(--radius-md);font-size:.875rem;animation:slideDown .3s ease;line-height:1.5}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.upload-message.error{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#ef4444}.upload-message.success{background:#22c55e26;border:1px solid rgba(34,197,94,.3);color:#22c55e}.message-icon{flex-shrink:0}.form-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-section h3{font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.upload-form textarea{width:100%;padding:var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:1rem;resize:vertical;transition:all var(--transition-fast)}.upload-form textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #8b5cf626}.difficulty-select{display:flex;gap:var(--spacing-sm)}.difficulty-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.difficulty-btn:hover{border-color:var(--border-light);background:var(--bg-secondary)}.difficulty-btn.active{color:var(--text-primary);font-weight:600}.difficulty-btn.active.easy{border-color:#22c55e;background:#22c55e26}.difficulty-btn.active.medium{border-color:#f59e0b;background:#f59e0b26}.difficulty-btn.active.hard{border-color:#ef4444;background:#ef444426}.difficulty-btn.active.hard{border-color:#f87171;background:#ef44441a}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;color:var(--text-primary);font-weight:500}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-color)}.checkbox-label span{-webkit-user-select:none;user-select:none}.dropzone{border:2px dashed var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-2xl);text-align:center;cursor:pointer;transition:all var(--transition-fast);background:var(--bg-tertiary)}.dropzone:hover{border-color:var(--primary-color);background:#8b5cf60d}.dropzone.has-image{padding:var(--spacing-md);cursor:default}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.dropzone-icon{font-size:3rem;margin-bottom:var(--spacing-sm)}.dropzone-text{font-weight:500;color:var(--text-primary)}.dropzone-hint{font-size:.875rem;color:var(--text-muted)}.image-preview{position:relative;display:inline-block}.image-preview img{max-width:100%;max-height:300px;border-radius:var(--radius-md);object-fit:contain}.clear-image{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:32px;height:32px;border-radius:50%;background:#000000b3;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all var(--transition-fast)}.clear-image:hover{background:#ef4444;transform:scale(1.1)}.submit-btn{width:100%}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin-right:var(--spacing-sm)}@media(max-width:480px){.upload-page{padding:var(--spacing-md)}.upload-form{padding:var(--spacing-lg)}.difficulty-select{flex-direction:column}.dropzone{padding:var(--spacing-xl)}}.gallery-container{animation:fadeIn .5s ease}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.puzzle-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;text-decoration:none;color:inherit;transition:all var(--transition-base);animation:fadeIn .5s ease backwards}.puzzle-card:hover{transform:translateY(-8px);border-color:var(--primary-color);box-shadow:var(--shadow-xl),var(--shadow-glow)}.puzzle-card-image{position:relative;width:100%;height:180px;overflow:hidden}.puzzle-card-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.puzzle-card:hover .puzzle-card-image img{transform:scale(1.1)}.puzzle-card-overlay{position:absolute;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-base)}.puzzle-card:hover .puzzle-card-overlay{opacity:1}.play-icon{width:60px;height:60px;background:var(--gradient-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;box-shadow:var(--shadow-lg);transform:scale(.8);transition:transform var(--transition-base)}.puzzle-card:hover .play-icon{transform:scale(1)}.puzzle-card-content{padding:var(--spacing-lg)}.puzzle-card-title{font-size:1.125rem;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.puzzle-card-meta{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.differences-count{font-size:.875rem;color:var(--text-muted)}.difficulty-rating{display:inline-flex;align-items:center;font-size:.8rem;font-weight:700;font-variant-numeric:tabular-nums}.rating-easy{color:#22c55e}.rating-medium{color:#f59e0b}.rating-hard{color:#ef4444}.gallery-controls{display:flex;justify-content:flex-end;margin-bottom:var(--spacing-lg)}.sort-btn{display:inline-flex;align-items:center;gap:6px;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-base)}.sort-btn:hover{border-color:var(--primary-color);color:var(--primary-color);background:var(--bg-card-hover, var(--bg-card))}.sort-btn.sort-active{border-color:var(--primary-color);color:var(--primary-color);background:#6366f114}.empty-state{text-align:center;padding:var(--spacing-2xl);background:var(--bg-card);border:2px dashed var(--border-color);border-radius:var(--radius-xl)}.empty-icon{font-size:4rem;margin-bottom:var(--spacing-md);opacity:.5}.empty-state h3{margin-bottom:var(--spacing-sm)}.empty-state p{margin-bottom:var(--spacing-lg)}.error-banner{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-lg);color:#ef4444;margin-bottom:var(--spacing-lg)}.skeleton-card{pointer-events:none}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-card-hover) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.skeleton-image{width:100%;height:180px}.skeleton-content{padding:var(--spacing-lg)}.skeleton-title{height:24px;border-radius:var(--radius-sm);margin-bottom:var(--spacing-sm)}.skeleton-text{height:16px;width:60%;border-radius:var(--radius-sm)}.load-more-container{display:flex;justify-content:center;margin-top:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.load-more-btn{padding:var(--spacing-md) var(--spacing-xl);background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-lg);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-md)}.load-more-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.load-more-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--spacing-md)}.puzzle-card-image{height:150px}}@media(max-width:480px){.gallery-grid{grid-template-columns:1fr}}.puzzle-card.unpublished{opacity:.65;border-color:#f59e0b66}.unpublished-badge{position:absolute;top:8px;left:8px;background:#f59e0be6;color:#fff;font-size:.65rem;font-weight:800;letter-spacing:1px;padding:2px 8px;border-radius:4px}.publish-toggle{all:unset;cursor:pointer;font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:4px;letter-spacing:.5px;transition:background .2s,color .2s;white-space:nowrap}.publish-toggle.published{background:#22c55e26;color:#22c55e}.publish-toggle.published:hover{background:#22c55e4d}.publish-toggle.draft{background:#f59e0b26;color:#f59e0b}.publish-toggle.draft:hover{background:#f59e0b4d}.puzzle-detail{animation:fadeIn .5s ease;max-width:1200px;margin:0 auto}.puzzle-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-lg)}.loading-spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.puzzle-error{text-align:center;padding:var(--spacing-2xl);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl)}.error-icon{font-size:4rem;margin-bottom:var(--spacing-md)}.puzzle-header{margin-bottom:var(--spacing-xl)}.back-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--text-muted);font-size:.875rem;margin-bottom:var(--spacing-md);transition:color var(--transition-fast)}.back-link:hover{color:var(--primary-light)}.puzzle-header h1{margin-bottom:var(--spacing-sm)}.puzzle-description{color:var(--text-secondary);font-size:1.125rem}.progress-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.progress-label{font-weight:600;color:var(--text-secondary);text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}.progress-count{font-weight:700;color:var(--text-primary);font-size:1.125rem}.progress-bar{height:12px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:var(--gradient-accent);border-radius:var(--radius-full);transition:width .5s ease;position:relative}.progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}.completion-message{margin-top:var(--spacing-md);padding:var(--spacing-md);background:#22c55e26;border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-lg);color:#22c55e;font-weight:600;text-align:center;animation:bounce .5s ease}.puzzle-controls{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.puzzle-controls button{flex:1;min-width:150px}.btn-active{background:var(--gradient-accent)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover{background:var(--border-light)}.puzzle-controls .publish-toggle{font-size:.85rem;font-weight:700;padding:.5rem 1rem;border-radius:var(--radius-md);border:none;cursor:pointer;letter-spacing:.5px;transition:background .2s}.puzzle-controls .publish-toggle.published{background:#22c55e26;color:#22c55e}.puzzle-controls .publish-toggle.published:hover{background:#22c55e4d}.puzzle-controls .publish-toggle.draft{background:#f59e0b26;color:#f59e0b}.puzzle-controls .publish-toggle.draft:hover{background:#f59e0b4d}.puzzle-game-area{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.puzzle-image-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden}.puzzle-image-container h3{padding:var(--spacing-md) var(--spacing-lg);margin:0;background:var(--bg-tertiary);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);text-align:center}.canvas-wrapper{padding:var(--spacing-md);display:flex;justify-content:center;align-items:center;min-height:300px;background:var(--bg-primary);position:relative}.canvas-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);color:var(--text-secondary)}.canvas-wrapper canvas{border-radius:var(--radius-md);cursor:crosshair;transition:transform var(--transition-fast)}.click-feedback{position:fixed;transform:translate(-50%,-50%);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;pointer-events:none;animation:feedbackPop .5s ease forwards;z-index:1000}.click-feedback.success{background:#22c55ee6;color:#fff;box-shadow:0 0 20px #22c55e80}.click-feedback.miss{background:#ef4444e6;color:#fff;box-shadow:0 0 20px #ef444480}.puzzle-info{display:flex;gap:var(--spacing-lg);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-lg)}.info-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.info-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}.info-value{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-secondary)}.badge-easy{background:#22c55e26;color:#22c55e}.badge-medium{background:#f59e0b26;color:#f59e0b}.badge-hard{background:#ef444426;color:#ef4444}@media(max-width:900px){.puzzle-game-area{grid-template-columns:1fr}.puzzle-controls{flex-direction:column}.puzzle-controls button{width:100%}}@media(max-width:480px){.puzzle-info{flex-direction:column;gap:var(--spacing-md)}}.arcade-mode{margin:0 auto;padding:0;font-family:Segoe UI,Helvetica Neue,Arial,sans-serif;display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.main-content:has(.arcade-mode){padding:.25rem}.arcade-menu,.arcade-gameover,.arcade-leaderboard{max-width:960px;margin:0 auto;width:100%}.ph-cabinet{background:linear-gradient(180deg,#0b1a3e,#0f2557 40%,#0b1a3e);border:4px solid #5c6b8a;border-radius:16px;box-shadow:0 0 0 2px #1e2d53,0 0 30px #1e5adc40,inset 0 1px #ffffff0d;overflow:hidden;color:#e4ecff;animation:fadeIn .4s}.ph-cabinet{display:flex;flex-direction:column;height:100%}.arcade-game.ph-cabinet{flex:1;min-height:0;overflow:hidden}.ph-title-bar{background:linear-gradient(180deg,#c0392b,#962d22);text-align:center;padding:.6rem 1rem;border-bottom:3px solid #7a1f16}.ph-logo,.ph-logo-sm{font-family:Arial Black,sans-serif;font-weight:900;text-transform:uppercase;letter-spacing:2px;text-shadow:2px 2px 0 rgba(0,0,0,.5)}.ph-logo{font-size:1.6rem;color:#ffe066}.ph-logo-sm{font-size:1.1rem;color:#ffe066;letter-spacing:3px}.ph-top-bar{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(180deg,#c0392b,#962d22);padding:.35rem .8rem;border-bottom:3px solid #7a1f16;flex-wrap:wrap;gap:.25rem;flex-shrink:0}.ph-top-stats{display:flex;gap:1rem}.ph-stat{display:flex;align-items:center;gap:.3rem;background:#00000059;border-radius:6px;padding:.2rem .6rem;border:1px solid rgba(255,255,255,.12)}.ph-stat-icon{font-size:1rem}.ph-stat-val{font-family:Courier New,monospace;font-weight:700;font-size:1.3rem;color:#ffe066;text-shadow:0 0 6px rgba(255,224,102,.6);min-width:2ch;text-align:right}.ph-stat-val.ph-warn{color:#f44;animation:pulse .8s infinite;text-shadow:0 0 8px rgba(255,68,68,.7)}.ph-score-stat .ph-stat-val{color:#4cff72;text-shadow:0 0 6px rgba(76,255,114,.5)}.ph-highscore{font-size:.7rem;letter-spacing:1px;color:#ffd1d1;text-transform:uppercase;text-align:right}.ph-highscore span{font-weight:700;font-family:Courier New,monospace;color:#ffe066;font-size:.85rem}.ph-bottom-bar{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(180deg,#162a5a,#0e1d40);border-top:3px solid #5c6b8a;padding:.4rem 1rem;gap:.5rem;flex-shrink:0}.ph-round{font-family:Arial Black,sans-serif;font-size:.95rem;letter-spacing:3px;color:#8eaadb;text-transform:uppercase}.ph-diff-count{font-family:Courier New,monospace;font-weight:700;font-size:1.1rem;color:#ffe066;text-shadow:0 0 6px rgba(255,224,102,.5)}.ph-clues{display:flex;gap:.35rem}.ph-clue-icon{background:none;border:none;font-size:1.5rem;cursor:pointer;filter:drop-shadow(0 0 4px rgba(255,255,255,.4));transition:transform .15s,filter .2s;padding:0;line-height:1}.ph-clue-icon.available:hover{transform:scale(1.25);filter:drop-shadow(0 0 8px #ffe066)}.ph-clue-icon.used{opacity:.25;cursor:default;filter:grayscale(1)}.timebar-container{margin:0;padding:0 .6rem;background:#0e1d40;flex-shrink:0}.timebar-track{width:100%;height:10px;background:#ffffff14;border-radius:5px;overflow:hidden}.timebar-fill{height:100%;background:linear-gradient(90deg,#4cff72,#06b6d4);transition:width .9s linear,background .3s;border-radius:5px}.timebar-fill.warning{background:linear-gradient(90deg,#f97316,#f44);box-shadow:0 0 8px #ff444480;animation:pulse .8s infinite}.ph-images-frame{padding:.5rem .6rem;background:linear-gradient(180deg,#0f2050,#132b60)}.ph-images-frame{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;overflow:hidden}.arcade-images-container{display:flex;justify-content:center;align-items:stretch;gap:0}.arcade-images-container{flex:1 1 auto;min-height:0}.ph-divider{width:3px;background:#5c6b8a;flex-shrink:0}.arcade-image-wrapper{flex:1;min-width:0;display:flex;align-items:center;justify-content:center}.arcade-image-wrapper{flex:1 1 50%;min-height:0}.canvas-wrapper{position:relative;display:flex;justify-content:center;align-items:center;width:100%;min-height:0}.canvas-wrapper canvas{max-width:100%;height:auto;border:2px solid #3a4d7a;display:block}.canvas-wrapper{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}.canvas-wrapper canvas{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.arcade-puzzle-container{position:relative;flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.arcade-message-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#000000b8;z-index:50;animation:overlayFadeIn .35s ease-out;pointer-events:none}.arcade-message-text{color:#ffe066;font-size:clamp(1.8rem,5vw,3rem);font-weight:900;letter-spacing:3px;text-transform:uppercase;text-align:center;text-shadow:0 0 12px rgba(255,224,102,.9),0 0 30px rgba(255,165,0,.5),0 2px 4px rgba(0,0,0,.8);padding:1rem 2rem;animation:overlayPulse .6s ease-in-out}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes overlayPulse{0%{transform:scale(.6);opacity:0}60%{transform:scale(1.1);opacity:1}to{transform:scale(1);opacity:1}}.arcade-loading{text-align:center;font-size:1.2rem;padding:3rem;color:#8eaadb;flex:1;display:flex;align-items:center;justify-content:center}.click-feedback{position:fixed;transform:translate(-50%,-50%);width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;pointer-events:none;animation:feedbackPop .5s ease forwards;z-index:1000}.click-feedback.success{background:#4cff72e6;color:#0b1a3e;box-shadow:0 0 18px #4cff7299}.click-feedback.miss{background:#ff4444e6;color:#fff;box-shadow:0 0 18px #f449}.arcade-menu{text-align:center;animation:fadeIn .5s}.ph-menu-body{padding:2rem 1.5rem}.arcade-rules{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem}.rule-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);padding:1.2rem .8rem;border-radius:10px;transition:transform .2s,background .2s}.rule-card:hover{transform:translateY(-3px);background:#ffffff1a}.rule-icon{font-size:2.2rem;margin-bottom:.5rem}.rule-card h3{font-size:1rem;margin-bottom:.25rem;color:#ffe066}.rule-card p{font-size:.85rem;color:#8eaadb}.best-score{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1.5rem}.best-score-label{font-size:.8rem;letter-spacing:2px;color:#8eaadb;text-transform:uppercase}.best-score-value{font-family:Courier New,monospace;font-size:2rem;font-weight:900;color:#ffe066;text-shadow:0 0 10px rgba(255,224,102,.5)}.menu-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn-arcade-start{background:linear-gradient(180deg,#e74c3c,#c0392b);color:#ffe066;border:2px solid #ff6b6b;padding:.75rem 2.5rem;font-family:Arial Black,sans-serif;font-size:1.2rem;letter-spacing:3px;border-radius:8px;cursor:pointer;text-transform:uppercase;transition:all .2s;box-shadow:0 4px 12px #e74c3c66}.btn-arcade-start:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #e74c3c99;border-color:#ffe066}.btn-arcade-start:disabled{opacity:.5;cursor:not-allowed}.btn-arcade-secondary{background:#ffffff14;color:#8eaadb;border:1px solid #5c6b8a;padding:.65rem 1.5rem;font-size:.85rem;border-radius:8px;cursor:pointer;letter-spacing:2px;text-transform:uppercase;font-weight:700;transition:all .2s}.btn-arcade-secondary:hover{background:#ffffff26;color:#ffe066;border-color:#ffe066}.btn-debug{background:#ffffff14;border:1px solid #5c6b8a;font-size:1rem;padding:.2rem .5rem;border-radius:6px;cursor:pointer;transition:all .2s;line-height:1}.btn-debug.on{background:#4cff7233;border-color:#4cff72}.arcade-gameover{text-align:center;animation:fadeIn .5s}.ph-gameover-body{padding:2.5rem 1rem}.ph-gameover-body .score-label{font-size:.9rem;letter-spacing:3px;color:#8eaadb;text-transform:uppercase;margin-bottom:.5rem}.ph-gameover-body .score-value{font-family:Courier New,monospace;font-size:4rem;font-weight:900;color:#ffe066;text-shadow:0 0 20px rgba(255,224,102,.5);margin:0}.new-record{font-size:1.2rem;color:#4cff72;margin-top:.5rem;animation:bounce 1s infinite}.gameover-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;padding:0 1rem 1.5rem}.arcade-leaderboard{animation:fadeIn .5s}.arcade-leaderboard h1{text-align:center;font-family:Arial Black,sans-serif;font-size:2rem;letter-spacing:4px;color:#ffe066;text-shadow:2px 2px 0 rgba(0,0,0,.5);margin-bottom:1.5rem}.leaderboard-table{background:#ffffff0a;border:1px solid #3a4d7a;border-radius:10px;overflow:hidden;margin-bottom:1.5rem}.leaderboard-header{display:grid;grid-template-columns:60px 1fr 100px 130px;gap:.5rem;padding:.75rem 1rem;background:linear-gradient(180deg,#c0392b,#962d22);color:#ffe066;font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:2px}.leaderboard-row{display:grid;grid-template-columns:60px 1fr 100px 130px;gap:.5rem;padding:.65rem 1rem;border-bottom:1px solid rgba(255,255,255,.06);color:#c5d4f0;font-size:.9rem;transition:background .15s}.leaderboard-row:hover{background:#ffffff0f}.leaderboard-row.current-user{background:#ffe0661a}.rank-col{text-align:center}.leaderboard-row .rank-col{font-size:1.2rem}.leaderboard-header .rank-col{font-size:.75rem}.player-col{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.score-col{text-align:right;font-weight:700;color:#4cff72}.date-col{text-align:right;color:#7b8db5;font-size:.8rem}.no-scores{text-align:center;padding:2rem;color:#8eaadb;font-size:1.1rem}.arcade-leaderboard .btn-arcade-secondary{display:block;margin:0 auto}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes feedbackPop{0%{opacity:1;transform:translate(-50%,-50%) scale(.5)}50%{transform:translate(-50%,-50%) scale(1.2)}to{opacity:0;transform:translate(-50%,-100%) scale(1)}}.credits-display{display:flex;flex-direction:column;align-items:center;gap:.35rem;margin:.8rem 0}.credits-display.compact{margin:.6rem 0 0}.credits-coins{display:flex;gap:.5rem;font-size:1.6rem}.credit-coin{transition:opacity .3s,filter .3s}.credit-coin.active{opacity:1;filter:drop-shadow(0 0 6px rgba(255,200,50,.8))}.credit-coin.empty{opacity:.25;filter:grayscale(1)}.credits-label{font-size:.85rem;font-weight:700;color:#8eaadb;letter-spacing:1px}.credits-regen{font-size:.78rem;color:#f59e0b;font-weight:600;letter-spacing:.5px}.btn-add-credit{background:#22c55e33;border:1px solid rgba(34,197,94,.5);color:#22c55e;padding:.25rem .6rem;border-radius:4px;font-size:.7rem;font-weight:700;letter-spacing:1px;cursor:pointer;transition:background .2s}.btn-add-credit:hover{background:#22c55e59}@media(max-width:640px){.arcade-mode{padding:.5rem;margin:0}.ph-logo{font-size:1.5rem}.ph-logo-sm{font-size:.85rem}.ph-top-bar{padding:.25rem .5rem}.ph-stat-val{font-size:1rem}.ph-bottom-bar{padding:.3rem .5rem;flex-wrap:wrap}.ph-round{font-size:.75rem}.ph-clue-icon{font-size:1.2rem}.arcade-rules{grid-template-columns:1fr;gap:.6rem}.menu-actions{flex-direction:column}.btn-arcade-start,.btn-arcade-secondary{width:100%}.gameover-actions{flex-direction:column}.leaderboard-header,.leaderboard-row{grid-template-columns:50px 1fr 80px}.date-col{display:none}}@media(orientation:landscape)and (min-height:380px){.arcade-images-container{flex-wrap:nowrap}.canvas-wrapper canvas{max-height:75vh}}@media(orientation:portrait){.arcade-images-container{flex-direction:column;align-items:stretch}.ph-divider{width:100%;height:3px;flex-shrink:0}.arcade-image-wrapper{width:100%;display:flex;justify-content:center;padding:.4rem 0}.canvas-wrapper canvas{max-width:92%;max-height:45vh;height:auto}}.app-container{height:100vh;height:100dvh;display:flex;flex-direction:column;overflow:hidden}.navbar{position:sticky;top:0;z-index:100;background:#0f172af2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);padding:var(--spacing-md) 0}.navbar-content{max-width:1400px;margin:0 auto;padding:0 var(--spacing-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-lg)}.navbar-brand{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.25rem;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none}.navbar-brand-icon{font-size:1.5rem}.navbar-links{display:flex;align-items:center;gap:var(--spacing-md)}.nav-link{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);color:var(--text-secondary);font-weight:500;border-radius:var(--radius-md);transition:all var(--transition-fast)}.nav-link:hover{color:var(--text-primary);background:var(--bg-tertiary)}.nav-link.active{color:var(--primary-light);background:#6366f126}.navbar-actions{display:flex;align-items:center;gap:var(--spacing-md)}.user-badge{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-full);font-size:.875rem;color:var(--text-secondary)}.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;color:#fff}.main-content{flex:1;min-height:0;width:100%;max-width:1400px;margin:0 auto;padding:var(--spacing-xl) var(--spacing-lg);display:flex;flex-direction:column;overflow:auto}.page-header{text-align:center;margin-bottom:var(--spacing-2xl);animation:fadeIn .5s ease}.page-header h1{margin-bottom:var(--spacing-sm)}.page-header p{font-size:1.125rem;max-width:600px;margin:0 auto}.home-hero{text-align:center;padding:var(--spacing-2xl) 0;animation:fadeIn .6s ease}.home-hero h1{font-size:clamp(2.5rem,6vw,4rem);margin-bottom:var(--spacing-lg);line-height:1.1}.home-hero-subtitle{font-size:1.25rem;color:var(--text-secondary);max-width:600px;margin:0 auto var(--spacing-xl)}.home-hero-actions{display:flex;justify-content:center;gap:var(--spacing-md);flex-wrap:wrap}.home-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-2xl)}.feature-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--spacing-xl);text-align:center;transition:all var(--transition-base)}.feature-card:hover{transform:translateY(-4px);border-color:var(--primary-color);box-shadow:var(--shadow-lg),var(--shadow-glow)}.feature-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.feature-card h3{margin-bottom:var(--spacing-sm)}.feature-card p{font-size:.9375rem;margin:0}.mobile-menu-btn{display:none;padding:var(--spacing-sm);background:transparent;border:none;box-shadow:none;color:var(--text-primary)}.mobile-menu-btn:hover{background:var(--bg-tertiary);transform:none;box-shadow:none}@media(max-width:768px){.navbar-content{flex-wrap:wrap}.mobile-menu-btn{display:flex}.navbar-links{display:none;width:100%;flex-direction:column;padding-top:var(--spacing-md);border-top:1px solid var(--border-color);margin-top:var(--spacing-md)}.navbar-links.open{display:flex}.nav-link{width:100%;justify-content:center}.navbar-actions{display:none}.navbar-actions.open{display:flex;width:100%;justify-content:center;padding-top:var(--spacing-md)}.home-hero-actions{flex-direction:column;align-items:center}.home-hero-actions button{width:100%;max-width:300px}}.footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:var(--spacing-lg);text-align:center;color:var(--text-muted);font-size:.875rem}:root{--primary-color: #6366f1;--primary-hover: #4f46e5;--primary-light: #818cf8;--primary-dark: #4338ca;--accent-color: #10b981;--accent-hover: #059669;--accent-light: #34d399;--warning-color: #f59e0b;--error-color: #ef4444;--success-color: #22c55e;--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-card: #1e293b;--bg-card-hover: #273549;--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-muted: #64748b;--border-color: #334155;--border-light: #475569;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -2px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .5), 0 10px 10px -5px rgba(0, 0, 0, .3);--shadow-glow: 0 0 20px rgba(99, 102, 241, .3);--gradient-primary: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--gradient-accent: linear-gradient(135deg, #10b981 0%, #06b6d4 100%);--gradient-dark: linear-gradient(180deg, #0f172a 0%, #1e293b 100%);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", Consolas, monospace;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}img{max-width:100%;height:auto;display:block}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);background:var(--gradient-dark);background-attachment:fixed;color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.3;color:var(--text-primary);margin-bottom:var(--spacing-md)}h1{font-size:clamp(1.75rem,4vw,2.5rem);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}h2{font-size:clamp(1.5rem,3vw,2rem)}h3{font-size:clamp(1.25rem,2.5vw,1.5rem)}h4{font-size:1.125rem;font-weight:600}p{color:var(--text-secondary);margin-bottom:var(--spacing-md)}a{color:var(--primary-light);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-color)}button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-family:var(--font-family);font-size:.9375rem;font-weight:600;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md)}button:hover,.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--shadow-glow)}button:active,.btn:active{transform:translateY(0)}button:disabled{opacity:.5;cursor:not-allowed;transform:none}input,select,textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-family);font-size:1rem;color:var(--text-primary);background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f133}input::placeholder{color:var(--text-muted)}input[type=file]{padding:var(--spacing-md);cursor:pointer}input[type=file]::file-selector-button{padding:var(--spacing-sm) var(--spacing-md);margin-right:var(--spacing-md);font-family:var(--font-family);font-weight:600;color:#fff;background:var(--gradient-primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--spacing-sm) center;background-size:1.25rem;padding-right:2.5rem}label{display:block;font-weight:600;color:var(--text-secondary);margin-bottom:var(--spacing-xs);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media(max-width:768px){html{font-size:14px}}@media(max-width:480px){html{font-size:13px}}
