*{margin:0;padding:0;box-sizing:border-box}html{overflow-y:auto;-ms-overflow-style:none;scrollbar-width:none;scroll-behavior:smooth}html::-webkit-scrollbar{display:none}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f0f0f0;overflow-x:hidden;-ms-overflow-style:none;scrollbar-width:none}body::-webkit-scrollbar{display:none}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background-color:#ff6b9d;color:#fff;padding:1.76rem;text-align:center}.app-header h1{font-size:2.64rem;margin-bottom:.44rem}.app-header p{font-size:1.32rem}.app-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.76rem}.loading{text-align:center}.spinner{width:44px;height:44px;border:4.4px solid #f0f0f0;border-top:4.4px solid #ff6b9d;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto .88rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading p{font-size:1.056rem;color:#333;margin-top:.88rem}.error{text-align:center;background-color:#ffe0e0;padding:1.6rem;border-radius:8px;border:2px solid #ff6b6b;max-width:400px}.error h2{color:#d63031;margin-bottom:.8rem}.error p{color:#333;margin-bottom:1.2rem}.error button{background-color:#ff6b9d;color:#fff;border:none;padding:.6rem 1.2rem;font-size:.8rem;border-radius:4px;cursor:pointer;transition:background-color .2s}.error button:hover{background-color:#ff4581}.status{text-align:center;background-color:#fff;padding:2rem;border-radius:10px;box-shadow:0 2px 10px #0000001a;max-width:500px}.status h2{color:#ff6b9d;margin-bottom:1rem}.status p{color:#333;margin-bottom:1.5rem;font-size:1.1rem}.status ul{list-style:none;padding:0;text-align:left}.status li{padding:.5rem 0;border-bottom:1px solid #f0f0f0;font-size:1rem}.status li:last-child{border-bottom:none}.app-main-active{padding:.88rem;justify-content:flex-start}.content-grid{display:grid;grid-template-columns:1.195fr .805fr;gap:1.76rem;width:100%;max-width:1109px;margin:0 auto;transform:scale(.792);transform-origin:top center}.webcam-section h2,.meme-section h2{color:#333;font-size:1.32rem;margin-bottom:.88rem;text-align:center}.webcam-container{display:flex;flex-direction:column;gap:.88rem}.webcam-start-button{display:flex;justify-content:center;margin-top:1.32rem}.webcam-start-button .btn-start-timer{padding:1.32rem 3.52rem;font-size:1.76rem;font-weight:700;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border:none;border-radius:13.2px;cursor:pointer;transition:all .3s;box-shadow:0 7.04px 26.4px #4caf5099;animation:pulseGlow 1.5s ease-in-out infinite,buttonPulse 3s ease-in-out infinite}.webcam-start-button .btn-start-timer:hover{transform:scale(1.05);box-shadow:0 10.56px 35.2px #4caf50cc;animation:pulseGlow 1.5s ease-in-out infinite}.webcam-start-button .btn-start-timer .play-icon{display:inline-block;font-size:1.584rem;margin-right:.44rem;vertical-align:middle;animation:playIconPulse 1.5s ease-in-out infinite}.webcam-restart-button{display:flex;justify-content:flex-start;margin-top:1.32rem}.btn-restart-timer{padding:.88rem 1.76rem;font-size:1.1rem;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8.8px;cursor:pointer;transition:all .3s;box-shadow:0 4.4px 17.6px #667eea66;flex-shrink:0}.btn-restart-timer:hover{transform:translateY(-2.2px);box-shadow:0 6.6px 22px #667eea99;background:linear-gradient(135deg,#5568d3,#6a3d8a)}.tip-box{flex:1;background:linear-gradient(135deg,#ff6b9d1a,#667eea1a);border:2.2px solid rgba(102,126,234,.3);border-radius:8.8px;padding:.88rem 1.32rem;display:flex;align-items:center;gap:.88rem;transition:opacity .3s ease-in-out,transform .3s ease-in-out}.tip-box.fade-in{opacity:1;transform:translateY(0)}.tip-box.fade-out{opacity:0;transform:translateY(-8.8px)}.tip-icon{font-size:1.76rem;flex-shrink:0}.tip-text{flex:1;font-size:.968rem;color:#333;font-weight:600;line-height:1.4}.video-wrapper{position:relative;background-color:#000;border-radius:8.8px;overflow:hidden;aspect-ratio:4 / 3}.webcam-video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.webcam-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;transform:scaleX(-1)}.timer-overlay{position:absolute;top:.88rem;left:.88rem;z-index:10;pointer-events:none}.timer-compact{display:flex;align-items:center;gap:.44rem;background:#000000b3;-webkit-backdrop-filter:blur(8.8px);backdrop-filter:blur(8.8px);padding:.44rem .88rem;border-radius:7.04px;box-shadow:0 1.76px 8.8px #0000004d}.timer-icon-small{font-size:1.056rem}.timer-value-small{font-size:1.32rem;font-weight:700;color:#fff;font-family:Courier New,monospace;letter-spacing:.05em}.video-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#1a1a1a;color:#fff}.video-placeholder p{font-size:1.056rem;opacity:.7}.webcam-controls{display:flex;justify-content:center;gap:.88rem}.btn-primary,.btn-secondary{padding:.6rem 1.6rem;font-size:.8rem;font-weight:600;border:none;border-radius:4px;cursor:pointer;transition:all .2s}.btn-primary{background-color:#ff6b9d;color:#fff}.btn-primary:hover{background-color:#ff4581;transform:translateY(-2px);box-shadow:0 4px 8px #ff6b9d4d}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#5a6268}.webcam-error{background-color:#ffe0e0;padding:1.1rem;border-radius:5.5px;border:1.1px solid #ff6b6b;text-align:center}.webcam-error p{color:#d63031;margin:.55rem 0}.webcam-error .help-text{font-size:.99rem;color:#666}.status-indicator{display:flex;align-items:center;justify-content:center;gap:.55rem;color:#666;font-size:.99rem}.status-dot{width:11px;height:11px;background-color:#4caf50;border-radius:50%;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.meme-display{display:flex;align-items:flex-start;justify-content:center;width:100%}.meme-placeholder{text-align:center;padding:2.64rem;background-color:#f9f9f9;border:2.2px dashed #ddd;border-radius:8.8px}.meme-placeholder p{color:#999;font-size:1.056rem}.meme-card{background-color:#fff;border-radius:8.8px;box-shadow:0 3.52px 17.6px #0000001a;overflow:hidden;width:100%;transition:transform .3s}.new-match .meme-card{animation:pop .5s ease-out}.meme-card.unlock-pop{animation:unlockMemePop .6s ease-out}@keyframes pop{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}@keyframes unlockMemePop{0%{transform:scale(1) rotate(0)}25%{transform:scale(.9) rotate(-3deg)}50%{transform:scale(1.15) rotate(3deg)}75%{transform:scale(.95) rotate(-2deg)}to{transform:scale(1) rotate(0)}}.meme-image-container{width:100%;aspect-ratio:1;overflow:hidden;background-color:#f0f0f0}.meme-image{width:100%;height:100%;object-fit:contain}.meme-info{padding:1.32rem}.meme-info h3{color:#333;font-size:1.32rem;margin-bottom:.44rem}.expression-label{color:#ff6b9d;font-size:.88rem;font-weight:600;text-transform:capitalize;margin-bottom:.88rem}.similarity-bar{margin-top:.88rem}.similarity-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:.44rem;font-size:.792rem;color:#666}.similarity-percentage{font-size:1.32rem;font-weight:700;color:#ff6b9d}.similarity-progress{height:8.8px;background-color:#f0f0f0;border-radius:4.4px;overflow:hidden}.similarity-fill{height:100%;background:linear-gradient(90deg,#ff6b9d,#ff4581);border-radius:4.4px;transition:width .5s ease-out}.info-bar{margin-top:2rem;text-align:center;color:#666;font-size:.9rem}.capture-hint{text-align:center;margin-top:1rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;font-size:1rem;font-weight:600;animation:slideIn .3s ease-out,glow 2s ease-in-out infinite}.capture-hint kbd{background-color:#fff3;padding:.25rem .75rem;border-radius:5px;font-family:monospace;font-weight:700;margin:0 .25rem;border:1px solid rgba(255,255,255,.3)}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes glow{0%,to{box-shadow:0 0 10px #667eea80}50%{box-shadow:0 0 20px #667eeacc}}.capture-screen{width:100%;max-width:900px;margin:0 auto;padding:2rem}.capture-container{background-color:#fff;border-radius:15px;box-shadow:0 10px 40px #0000001a;padding:2rem;text-align:center}.capture-container h2{color:#ff6b9d;font-size:2rem;margin-bottom:2rem}.shareable-graphic{margin-bottom:2rem;display:flex;justify-content:center}.shareable-graphic canvas{max-width:100%;height:auto;border-radius:10px;box-shadow:0 4px 20px #00000026}.capture-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:1.5rem}.capture-actions button{min-width:150px}.capture-details{color:#666;font-size:1rem;line-height:1.6}.capture-details strong{color:#ff6b9d}.btn-calibration{position:absolute;top:.8rem;right:.8rem;background-color:#667eea;color:#fff;border:none;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.72rem;font-weight:600;transition:all .2s}.btn-calibration:hover{background-color:#5568d3;transform:translateY(-1.6px)}.btn-easy-mode{position:absolute;top:.8rem;right:9.6rem;background-color:#ffa726;color:#fff;border:none;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.72rem;font-weight:600;transition:all .2s;border:2px solid transparent}.btn-easy-mode:hover{background-color:#fb8c00;transform:translateY(-2px)}.btn-easy-mode.active{background-color:#4caf50;border-color:#45a049;box-shadow:0 0 10px #4caf5080}.btn-easy-mode.active:hover{background-color:#45a049}.app-header{position:relative}.calibration-mode{width:100%;max-width:1400px;margin:0 auto;padding:2rem}.calibration-header{text-align:center;margin-bottom:2rem}.calibration-header h2{color:#333;font-size:2rem;margin-bottom:.5rem}.calibration-header p{color:#666;font-size:1rem;margin-bottom:1rem}.calibration-content{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.calibration-video-section{display:flex;flex-direction:column;gap:1rem}.calibration-controls{display:flex;flex-direction:column;gap:1.5rem}.expression-selector{display:flex;flex-direction:column;gap:.5rem}.expression-selector label{font-weight:600;color:#333;font-size:1rem}.expression-dropdown{padding:.75rem;font-size:1rem;border:2px solid #ddd;border-radius:5px;background-color:#fff;cursor:pointer;transition:border-color .2s}.expression-dropdown:hover{border-color:#ff6b9d}.expression-dropdown:focus{outline:none;border-color:#ff6b9d;box-shadow:0 0 0 3px #ff6b9d1a}.capture-instruction{background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem;border-radius:10px;color:#fff;text-align:center}.instruction-text{margin:0;font-size:1rem}.instruction-text kbd{background-color:#fff3;padding:.25rem .5rem;border-radius:3px;font-family:monospace;font-weight:700;margin:0 .25rem}.calibration-data-section{background-color:#fff;padding:1.5rem;border-radius:10px;box-shadow:0 2px 10px #0000001a}.calibration-data-section h3{color:#333;font-size:1.2rem;margin-bottom:1rem}.captured-list{display:flex;flex-direction:column;gap:.5rem}.captured-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background-color:#f9f9f9;border-radius:5px;border:2px solid transparent;transition:all .2s}.captured-item.captured{background-color:#e8f5e9;border-color:#4caf50}.capture-status{font-size:1.2rem;font-weight:700;min-width:20px}.captured-item.captured .capture-status{color:#4caf50}.capture-time{margin-left:auto;font-size:.85rem;color:#666;font-family:monospace}.calibration-actions{display:flex;gap:1rem}.calibration-actions button{flex:1}@media (max-width: 1024px){.content-grid{grid-template-columns:1fr;gap:1.5rem}.calibration-content{grid-template-columns:1fr}}@media (max-width: 768px){.app-header h1{font-size:1.6rem}.app-header p,.webcam-section h2,.meme-section h2{font-size:.96rem}.webcam-start-button .btn-start-timer{padding:.8rem 1.6rem;font-size:1.04rem}.webcam-start-button .btn-start-timer .play-icon{font-size:1.12rem}.btn-restart-timer{padding:.6rem 1.2rem;font-size:.9rem}.webcam-controls{flex-direction:column;gap:.8rem}.tip-box{width:100%}.tip-text{font-size:.85rem}.capture-screen{padding:1rem}.capture-container{padding:1.5rem}.capture-container h2{font-size:1.5rem}.capture-actions{flex-direction:column}.capture-actions button{width:100%}}.unlockable-faces{position:relative;width:100%;max-width:1300px;margin:0 auto -.88rem;padding:.88rem;border-radius:13.2px;transform:scale(.792);transform-origin:top center}.btn-info-unlockable{position:absolute;top:.88rem;right:.88rem;background-color:#667eeae6;color:#fff;border:none;width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:1.76rem;transition:all .3s;box-shadow:0 3.2px 12px #667eea66;z-index:5;display:flex;align-items:center;justify-content:center}.btn-info-unlockable:hover{background-color:#667eea;transform:scale(1.1);box-shadow:0 4.8px 16px #667eea99}.start-button-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-radius:12px;z-index:10}.btn-start-timer-overlay{padding:1.2rem 3.2rem;font-size:1.6rem;font-weight:700;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .3s;box-shadow:0 6.4px 24px #4caf5099;animation:pulseGlow 1.5s ease-in-out infinite}.btn-start-timer-overlay:hover{transform:scale(1.05);box-shadow:0 9.6px 32px #4caf50cc}.faces-container{display:grid;grid-template-columns:repeat(8,1fr);gap:.88rem;padding:.44rem}.unlockable-face{display:flex;flex-direction:column;align-items:center;gap:.44rem}.face-image{position:relative;width:100%;aspect-ratio:1;border-radius:8.8px;overflow:hidden;box-shadow:0 1.76px 8.8px #00000026;transition:all .3s}.face-image.locked,.face-image.unlocked{opacity:1}.face-image.just-unlocked{animation:unlockPop .5s ease-out}@keyframes unlockPop{0%{transform:scale(.8) rotate(-5deg);opacity:.5}50%{transform:scale(1.1) rotate(5deg)}to{transform:scale(1) rotate(0);opacity:1}}.face-image img{width:100%;height:100%;object-fit:cover}.blur-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1}.blur-overlay:before{content:"🔒";font-size:1.76rem;opacity:.7;color:#fff}.progress-ring{position:absolute;top:0;left:0;width:100%;height:100%;z-index:10;pointer-events:none}.progress-ring path{transition:stroke-dasharray .1s linear;filter:drop-shadow(0 0 2px rgba(0,0,0,.9))}.unlock-badge{position:absolute;top:4.4px;right:4.4px;background-color:#4caf50;color:#fff;width:26.4px;height:26.4px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.056rem;font-weight:700;box-shadow:0 1.76px 4.4px #0003;animation:badgePop .3s ease-out .2s backwards}@keyframes badgePop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.face-label{font-size:.88rem;color:#666;text-align:center;text-transform:capitalize;font-weight:600}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999;overflow:hidden}.confetti-piece{position:absolute;width:10px;height:10px;top:-10px;animation:confettiFall 3s linear forwards}@keyframes confettiFall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.timer-display{display:flex;align-items:center;justify-content:center;gap:1rem;width:100%;max-width:1260px;margin:0 auto 2rem;padding:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px;box-shadow:0 4px 15px #0000001a;transform:scale(.9);transform-origin:top center}.timer-icon{font-size:2.5rem}.timer-value{font-size:3rem;font-weight:700;color:#fff;font-family:Courier New,monospace;letter-spacing:.1em}.timer-display .btn-start-timer{width:auto;padding:1.25rem 3rem;font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border:none;border-radius:10px;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px #4caf5066;animation:pulseGlow 1.5s ease-in-out infinite}.timer-display .btn-start-timer:hover{transform:scale(1.05);box-shadow:0 8px 30px #4caf50cc}@media (max-width: 1024px){.faces-container{grid-template-columns:repeat(4,1fr)}}@media (max-width: 768px){.faces-container{grid-template-columns:repeat(4,1fr);gap:.5rem}.face-label{font-size:.6rem}.unlockable-faces{margin-bottom:1rem;padding:.5rem}.btn-start-timer-overlay{padding:1rem 2rem;font-size:1.3rem}.timer-value,.timer-icon{font-size:2rem}.timer-display .btn-start-timer{padding:1rem 2rem;font-size:1.2rem}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease-out}.btn-close-modal{position:absolute;top:1.6rem;right:1.6rem;background:none;border:none;font-size:3.2rem;color:#999;cursor:pointer;transition:all .2s;width:48px;height:48px;display:flex;align-items:center;justify-content:center;line-height:1}.btn-close-modal:hover{color:#333;transform:scale(1.1)}.intro-modal-content{position:relative}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:#fff;border-radius:20px;padding:3rem;max-width:600px;width:90%;box-shadow:0 20px 60px #0000004d;animation:slideUp .4s ease-out}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.intro-modal h1{color:#ff6b9d;font-size:2.5rem;margin-bottom:1.5rem;text-align:center}.challenge-description{margin-bottom:2rem}.challenge-tagline{font-size:1.3rem;color:#333;text-align:center;margin-bottom:2rem;font-weight:600}.challenge-rules{background:linear-gradient(135deg,#ff6b9d1a,#667eea1a);border-radius:15px;padding:1.5rem}.challenge-rules h3{color:#667eea;font-size:1.2rem;margin-bottom:1rem}.challenge-rules ul{list-style:none;padding:0}.challenge-rules li{padding:.75rem 0;color:#333;font-size:1.1rem;border-bottom:1px solid rgba(0,0,0,.1)}.challenge-rules li:last-child{border-bottom:none}.btn-start{width:100%;padding:1.25rem 2rem;font-size:1.3rem;font-weight:700;background:linear-gradient(135deg,#ff6b9d,#ff4581);color:#fff;border:none;border-radius:10px;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px #ff6b9d66}.btn-start:hover{transform:translateY(-3px);box-shadow:0 8px 25px #ff6b9d99}.permission-modal,.ready-modal{text-align:center}.ready-title{font-size:4rem;color:#ff6b9d;margin-bottom:1rem;animation:pulse 1s ease-in-out infinite}.ready-subtitle{font-size:1.2rem;color:#666;margin-bottom:2rem}.btn-start-timer{width:100%;padding:1.5rem 2rem;font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border:none;border-radius:10px;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px #4caf5066;animation:pulseGlow 1.5s ease-in-out infinite}@keyframes pulseGlow{0%,to{box-shadow:0 4px 15px #4caf5066}50%{box-shadow:0 8px 30px #4caf50cc}}@keyframes buttonPulse{0%,90%,to{transform:scale(1)}95%{transform:scale(1.05)}}.btn-start-timer:hover{transform:scale(1.05)}.end-screen{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:1.6rem}.end-screen-content{background-color:#fff;border-radius:16px;padding:2.4rem;max-width:1120px;width:100%;box-shadow:0 16px 48px #0000004d;animation:slideUp .5s ease-out}.end-header{display:flex;align-items:center;justify-content:center;gap:1.6rem;margin-bottom:1.6rem;flex-wrap:wrap}.end-title{font-size:2.4rem;color:#ff6b9d;margin:0}.end-time{font-size:1.2rem;color:#666;margin:0}.time-display{font-size:2rem;font-weight:700;color:#667eea;margin-left:.4rem}.captures-grid{display:flex;justify-content:center;margin-bottom:1.6rem}.captures-canvas{max-width:100%;height:auto;border-radius:8px;box-shadow:0 3.2px 16px #00000026}.end-actions{display:flex;gap:.8rem;justify-content:center}.end-actions button{min-width:160px;padding:.8rem 1.6rem;font-size:.88rem}.loading-graphics{text-align:center;padding:3rem}.loading-graphics .spinner{width:50px;height:50px;border:5px solid #f0f0f0;border-top:5px solid #ff6b9d;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.loading-graphics p{font-size:1.2rem;color:#666}.graphics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem;margin-bottom:2rem;padding:1rem}.graphic-card{position:relative;background:#fff;border-radius:15px;box-shadow:0 4px 20px #0000001a;overflow:hidden;transition:transform .3s,box-shadow .3s}.graphic-card:hover{transform:translateY(-5px);box-shadow:0 8px 30px #00000026}.graphic-image{width:100%;height:auto;display:block}.btn-download-graphic{position:absolute;bottom:1rem;right:1rem;background:linear-gradient(135deg,#ff6b9d,#ff4581);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s;box-shadow:0 4px 15px #ff6b9d66;opacity:0}.graphic-card:hover .btn-download-graphic{opacity:1}.btn-download-graphic:hover{transform:scale(1.05);box-shadow:0 6px 20px #ff6b9d99}.capture-carousel{width:100%;margin-bottom:2rem}.carousel-header{text-align:center;margin-bottom:1.5rem}.carousel-title{font-size:2rem;color:#333;text-transform:capitalize;margin-bottom:.5rem}.carousel-counter{font-size:1.1rem;color:#666;font-weight:600}.carousel-content{display:flex;align-items:center;justify-content:center;gap:2rem;margin-bottom:1.5rem;position:relative}.carousel-image-container{max-width:680px;width:100%;border-radius:15px;overflow:hidden;box-shadow:0 10px 40px #0003}.carousel-image-container.carousel-card{position:relative;background:#fff}.carousel-image{width:100%;height:auto;object-fit:contain;display:block}.carousel-card .btn-download-graphic{opacity:0}.carousel-card:hover .btn-download-graphic{opacity:1}.carousel-btn{background-color:#ff6b9d33;border:2px solid #ff6b9d;color:#ff6b9d;font-size:3rem;font-weight:700;width:60px;height:60px;border-radius:50%;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1;padding:0}.carousel-btn:hover{background-color:#ff6b9d;color:#fff;transform:scale(1.1)}.carousel-dots{display:flex;justify-content:center;gap:.75rem;margin-bottom:1.5rem}.carousel-dot{width:12px;height:12px;border-radius:50%;border:2px solid #ddd;background-color:transparent;cursor:pointer;transition:all .3s;padding:0}.carousel-dot:hover{background-color:#ff6b9d80;border-color:#ff6b9d}.carousel-dot.active{background-color:#ff6b9d;border-color:#ff6b9d;transform:scale(1.3)}.carousel-actions{display:flex;justify-content:center}@media (max-width: 768px){.modal-content{padding:2rem}.intro-modal h1{font-size:2rem}.challenge-tagline{font-size:1.1rem}.challenge-rules li{font-size:1rem}.ready-title{font-size:3rem}.end-title,.time-display{font-size:2rem}.end-actions{flex-direction:column}.end-actions button{width:100%}.graphics-grid{grid-template-columns:1fr;gap:1.5rem}.btn-download-graphic{opacity:1;bottom:.5rem;right:.5rem;padding:.5rem 1rem;font-size:.9rem}}.calibration-header-actions{display:flex;gap:1rem;justify-content:center;margin-top:1rem}.calibration-main{display:flex;flex-direction:column;gap:2rem}.expression-grid{width:100%}.expression-grid h3{font-size:1.3rem;color:#333;margin-bottom:1rem;text-align:center}.expression-cards{display:grid;grid-template-columns:repeat(8,1fr);gap:.75rem}.expression-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem;background-color:#fff;border:3px solid transparent;border-radius:10px;cursor:pointer;transition:all .3s;position:relative}.expression-card:hover{border-color:#ff6b9d;transform:translateY(-3px);box-shadow:0 5px 15px #ff6b9d4d}.expression-card.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea1a,#764ba21a);box-shadow:0 5px 20px #667eea66}.expression-card.calibrated{background-color:#e8f5e9}.expression-img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px}.expression-name{font-size:.75rem;font-weight:600;color:#333;text-align:center}.calibrated-badge{position:absolute;top:5px;right:5px;width:24px;height:24px;background-color:#4caf50;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;box-shadow:0 2px 5px #0003}.calibration-workspace{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.calibration-video-section h3,.reference-display h3{font-size:1.2rem;color:#333;margin-bottom:1rem;text-align:center}.reference-display{display:flex;flex-direction:column;gap:1rem}.reference-meme-container{background-color:#fff;border-radius:15px;padding:1.5rem;box-shadow:0 4px 20px #0000001a;border:3px solid #667eea}.reference-meme{width:100%;aspect-ratio:1;object-fit:contain;border-radius:10px}.reference-name{text-align:center;font-size:1.3rem;font-weight:700;color:#667eea;margin-top:1rem}@media (max-width: 1200px){.expression-cards{grid-template-columns:repeat(4,1fr)}}@media (max-width: 1024px){.calibration-workspace{grid-template-columns:1fr}.expression-cards{grid-template-columns:repeat(4,1fr)}}@media (max-width: 768px){.expression-cards{grid-template-columns:repeat(2,1fr)}.expression-name{font-size:.65rem}.calibration-header-actions{flex-direction:column}}.capture-notification{position:fixed;bottom:2rem;right:2rem;z-index:10000;animation:toastSlideIn .3s ease-out}@keyframes toastSlideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.capture-notification-content{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border-radius:10px;box-shadow:0 8px 30px #4caf5080;font-size:1.1rem;font-weight:600}.capture-notification-icon{font-size:1.8rem;background-color:#fff3;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.capture-notification-text{display:flex;gap:.4rem}.capture-notification-text strong{font-weight:700}@media (max-width: 768px){.capture-notification{bottom:1rem;right:1rem;left:1rem}.capture-notification-content{font-size:1rem;padding:.75rem 1rem}.capture-notification-icon{width:35px;height:35px;font-size:1.5rem}}.error-notification{position:fixed;bottom:2rem;right:2rem;z-index:10000;animation:toastSlideIn .3s ease-out}.error-notification-content{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:linear-gradient(135deg,#f44336,#d32f2f);color:#fff;border-radius:10px;box-shadow:0 8px 30px #f4433680;font-size:1.1rem;font-weight:600}.error-notification-icon{font-size:1.8rem;background-color:#fff3;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.error-notification-text{display:flex;gap:.4rem}@media (max-width: 768px){.error-notification{bottom:1rem;right:1rem;left:1rem}.error-notification-content{font-size:1rem;padding:.75rem 1rem}.error-notification-icon{width:35px;height:35px;font-size:1.5rem}}.leaderboard-submit{margin:1.6rem 0;padding:0;background:none;border-radius:0;text-align:center}.leaderboard-submit h3{color:#667eea;font-size:1.2rem;margin-bottom:1.2rem}.submit-form{display:flex;gap:1rem;justify-content:center;align-items:center;flex-wrap:wrap}.submit-form input{flex:1;min-width:200px;max-width:320px;padding:.8rem 1.2rem;font-size:.88rem;border:2.4px solid #ddd;border-radius:8px;transition:all .3s;outline:none}.submit-form input:focus{border-color:#667eea;box-shadow:0 0 0 3.2px #667eea1a}.submit-form input:disabled{background-color:#f5f5f5;cursor:not-allowed}.btn-submit-leaderboard{padding:.8rem 2rem;font-size:.88rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s;box-shadow:0 3.2px 12px #667eea66}.btn-submit-leaderboard:hover:not(:disabled){transform:translateY(-1.6px);box-shadow:0 4.8px 16px #667eea99}.btn-submit-leaderboard:disabled{opacity:.6;cursor:not-allowed;transform:none}.submit-error{color:#d32f2f;margin-top:1rem;font-size:1rem;font-weight:600}.leaderboard-success{margin:1.6rem 0;padding:1.6rem;background:linear-gradient(135deg,#4caf501a,#45a0491a);border-radius:12px;text-align:center;border:2.4px solid #4caf50}.success-message{font-size:1.04rem;color:#4caf50;font-weight:700;margin-bottom:.4rem}.rank-display{font-size:.88rem;color:#666;margin-top:.4rem}.rank-display strong{font-size:1.44rem;color:#667eea;margin-left:.4rem}.leaderboard-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:1.6rem;display:flex;flex-direction:column}.leaderboard-header{display:flex;align-items:center;justify-content:space-between;gap:1.6rem;background-color:#fff;padding:1.6rem;border-radius:12px;box-shadow:0 3.2px 16px #0000001a;margin-bottom:1.6rem}.leaderboard-header h1{flex:1;text-align:center;color:#ff6b9d;font-size:2rem;margin:0}.btn-back{padding:.6rem 1.6rem;font-size:.8rem;font-weight:600;background-color:#6c757d;color:#fff;border:none;border-radius:6.4px;cursor:pointer;transition:all .3s;flex-shrink:0}.btn-back:hover{background-color:#5a6268;transform:translate(-2.4px)}.btn-refresh{padding:.6rem 1.6rem;font-size:.8rem;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6.4px;cursor:pointer;transition:all .3s;flex-shrink:0}.btn-refresh:hover{transform:translateY(-1.6px);box-shadow:0 3.2px 12px #667eea66}.leaderboard-split-container{display:flex;gap:2rem;flex:1;align-items:flex-start}.leaderboard-table-container{background-color:#fff;border-radius:12px;padding:1.6rem;box-shadow:0 3.2px 16px #0000001a;overflow-x:auto;flex:1;max-width:60%}.leaderboard-table{width:100%;border-collapse:collapse;font-size:.88rem}.leaderboard-table thead{background:linear-gradient(135deg,#667eea1a,#764ba21a)}.leaderboard-table th{padding:1rem;text-align:left;font-weight:700;color:#667eea;border-bottom:2.4px solid #667eea}.leaderboard-table tbody tr{border-bottom:.8px solid #f0f0f0;transition:background-color .2s}.leaderboard-table tbody tr:hover{background-color:#667eea0d}.leaderboard-table tbody tr.has-capture:hover{background-color:#667eea1a;cursor:pointer}.leaderboard-table tbody tr.selected{background-color:#667eea26;border-left:3.2px solid #667eea}.leaderboard-table td{padding:.8rem 1rem;color:#333}.rank-cell{font-weight:700;font-size:1.04rem;width:64px}.nickname-cell{font-weight:600;color:#667eea}.time-cell{font-family:Courier New,monospace;font-weight:600;color:#ff6b9d;font-size:.92rem}.date-cell{color:#999;font-size:.76rem}.leaderboard-table .rank-1{background:linear-gradient(135deg,#ffd70026,#ffc10726);font-weight:700}.leaderboard-table .rank-1 .rank-cell{font-size:1.44rem}.leaderboard-table .rank-2{background:linear-gradient(135deg,#c0c0c026,#a9a9a926);font-weight:600}.leaderboard-table .rank-2 .rank-cell{font-size:1.28rem}.leaderboard-table .rank-3{background:linear-gradient(135deg,#cd7f3226,#b8733326);font-weight:600}.leaderboard-table .rank-3 .rank-cell{font-size:1.12rem}.empty-message{text-align:center;font-size:1.04rem;color:#666;padding:2.4rem;background-color:#fff;border-radius:12px;box-shadow:0 3.2px 16px #0000001a}.leaderboard-error{text-align:center;background-color:#fff;padding:2.4rem;border-radius:12px;box-shadow:0 3.2px 16px #0000001a}.leaderboard-error p{color:#d32f2f;font-size:.96rem;margin-bottom:1.2rem}.btn-retry{padding:1rem 2rem;font-size:1rem;font-weight:600;background-color:#ff6b9d;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s}.btn-retry:hover{background-color:#ff4581;transform:translateY(-2px)}.leaderboard-preview-container{flex:1;max-width:40%;position:sticky;top:1.6rem}.capture-preview{background-color:#fff;border-radius:12px;padding:1.6rem;box-shadow:0 3.2px 16px #0000001a;animation:slideUp .3s ease-out}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.2rem}.preview-header h3{color:#667eea;font-size:1.2rem;margin:0}.btn-close-preview{background:none;border:none;font-size:1.8rem;color:#999;cursor:pointer;transition:color .2s;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.btn-close-preview:hover{color:#d32f2f}.preview-image-wrapper{margin-bottom:1.2rem;border-radius:8px;overflow:hidden;box-shadow:0 3.2px 12px #0000001a}.preview-image{width:100%;height:auto;display:block}.preview-info{display:flex;flex-direction:column;gap:.4rem}.preview-time{font-size:.88rem;color:#333;margin:0}.preview-time:before{content:"⏱️ "}.preview-date{font-size:.8rem;color:#999;margin:0}.preview-date:before{content:"📅 "}.preview-placeholder{background:linear-gradient(135deg,#667eea1a,#764ba21a);border:1.6px dashed #667eea;border-radius:12px;padding:3.2rem 1.6rem;text-align:center}.preview-placeholder p:first-child{font-size:3.2rem;margin-bottom:.8rem}.preview-placeholder p:last-child{font-size:.88rem;color:#667eea;margin:0;font-weight:600}.header-buttons{display:flex;gap:1rem;position:absolute;top:50%;right:1rem;transform:translateY(-50%)}.btn-leaderboard{background-color:gold;color:#333;border:none;padding:.6rem 1.2rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:700;transition:all .2s;box-shadow:0 2px 8px #ffd70066}.btn-leaderboard:hover{background-color:#ffc700;transform:translateY(-2px);box-shadow:0 4px 12px #ffd70099}.btn-info-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.6rem 1.2rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:700;transition:all .2s;box-shadow:0 2px 8px #667eea66;display:flex;align-items:center;gap:.5rem}.btn-info-header svg{width:1.1rem;height:1.1rem}.btn-info-header:hover{background:linear-gradient(135deg,#5568d3,#6a3d8a);transform:translateY(-2px);box-shadow:0 4px 12px #667eea99}@media (max-width: 1024px){.leaderboard-table{font-size:1rem}.leaderboard-table th,.leaderboard-table td{padding:.75rem 1rem}.rank-cell{font-size:1.1rem}.time-cell{font-size:1rem}}@media (max-width: 768px){.leaderboard-page{padding:1rem}.leaderboard-header{flex-direction:column;padding:1.5rem;gap:1rem}.leaderboard-header h1{font-size:2rem}.btn-back,.btn-refresh{width:100%}.leaderboard-split-container{flex-direction:column}.leaderboard-table-container{max-width:100%;padding:1rem;overflow-x:scroll}.leaderboard-preview-container{max-width:100%;position:static}.leaderboard-table{font-size:.9rem}.leaderboard-table th,.leaderboard-table td{padding:.5rem}.submit-form{flex-direction:column}.submit-form input,.btn-submit-leaderboard{width:100%}.header-buttons{flex-direction:column;gap:.5rem}.btn-leaderboard,.btn-info-header{font-size:.8rem;padding:.5rem 1rem}.btn-info-header svg{width:1rem;height:1rem}.preview-placeholder{padding:2rem 1rem}.preview-placeholder p:first-child{font-size:3rem}}.app-footer{background-color:#f8f9fa;color:#333;padding:1.2rem 1.6rem;text-align:center;margin-top:3.2rem}.app-footer p{margin:0;font-size:.8rem;font-family:Courier New,Courier,monospace}.app-footer a{color:#ff6b9d;text-decoration:none;font-weight:600;transition:color .2s}.app-footer a:hover{color:#ff4581;text-decoration:underline}@media (max-width: 768px){.app-footer{padding:1rem}.app-footer p{font-size:.9rem}}.snackbar{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);z-index:10000;animation:snackbarSlideUp .3s ease-out}@keyframes snackbarSlideUp{0%{transform:translate(-50%) translateY(100px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.snackbar-content{display:flex;align-items:center;gap:1rem;padding:1rem 2rem;background:linear-gradient(135deg,#ff6b9d,#ff4581);color:#fff;border-radius:12px;box-shadow:0 8px 30px #ff6b9d99;min-width:350px;max-width:600px}.snackbar-message{flex:1;font-size:1.1rem;font-weight:600;text-align:center}.snackbar-close{background:none;border:none;color:#fff;font-size:1.8rem;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;transition:opacity .2s;flex-shrink:0}.snackbar-close:hover{opacity:.7}@media (max-width: 768px){.snackbar{bottom:1rem;left:1rem;right:1rem;transform:none}@keyframes snackbarSlideUp{0%{transform:translateY(100px);opacity:0}to{transform:translateY(0);opacity:1}}.snackbar-content{min-width:auto;padding:.75rem 1.5rem}.snackbar-message{font-size:1rem}}.unlockable-faces-header{text-align:center;padding:1.5rem 2rem;margin-bottom:1.5rem}.unlockable-faces-header h2{color:#333;font-size:1.8rem;margin-bottom:.5rem;font-weight:700}.unlock-progress{font-size:1.2rem;color:#667eea;font-weight:600;margin:0}@media (max-width: 768px){.unlockable-faces-header h2{font-size:1.3rem}.unlock-progress{font-size:1rem}}.btn-start-timer-overlay .play-icon{display:inline-block;font-size:1.8rem;margin-right:.5rem;vertical-align:middle;animation:playIconPulse 1.5s ease-in-out infinite}@keyframes playIconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.countdown-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10001;animation:fadeIn .3s ease-out}.countdown-circle{width:240px;height:240px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;box-shadow:0 16px 48px #667eea99;animation:countdownPulse 1s ease-in-out}@keyframes countdownPulse{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.countdown-number{font-size:8rem;font-weight:900;color:#fff;text-shadow:0 8px 24px rgba(0,0,0,.5);animation:numberPop .5s ease-out}@keyframes numberPop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.countdown-go{font-size:4.8rem;font-weight:900;color:#4caf50;text-shadow:0 8px 24px rgba(76,175,80,.8);animation:goPop .5s ease-out}@keyframes goPop{0%{transform:scale(0) rotate(-180deg);opacity:0}70%{transform:scale(1.3) rotate(10deg)}to{transform:scale(1) rotate(0);opacity:1}}@media (max-width: 768px){.countdown-circle{width:160px;height:160px}.countdown-number{font-size:4.8rem}.countdown-go{font-size:3.2rem}}.intro-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:1.6rem;animation:fadeIn .5s ease-out}.intro-content{background-color:#fff;border-radius:24px;padding:3.2rem 2.4rem;max-width:720px;width:100%;box-shadow:0 24px 64px #0006;animation:slideUp .6s ease-out}.intro-header-section{display:flex;align-items:center;gap:2.4rem;margin-bottom:2rem}.intro-text{flex:1;text-align:left}.intro-mascot{width:176px;height:auto;flex-shrink:0;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.intro-content h1{color:#ff6b9d;font-size:2.8rem;margin-bottom:.8rem;font-weight:900;text-shadow:1.6px 1.6px 3.2px rgba(0,0,0,.1);text-align:left}.intro-description{font-size:1.12rem;color:#333;margin-bottom:0;font-weight:600;line-height:1.6;text-align:left}.intro-instructions{background:linear-gradient(135deg,#ff6b9d1a,#667eea1a);border-radius:16px;padding:1.6rem;margin-bottom:2rem;text-align:left}.intro-instructions h2{color:#667eea;font-size:1.2rem;margin-bottom:.8rem;text-align:center}.intro-instructions ol{list-style:none;padding:0;counter-reset:instruction-counter}.intro-instructions li{counter-increment:instruction-counter;color:#333;font-size:.92rem;border-bottom:1px solid rgba(0,0,0,.1);position:relative;padding:.8rem 0 .8rem 2.4rem;line-height:1.6}.intro-instructions li:last-child{border-bottom:none}.intro-instructions li:before{content:counter(instruction-counter);position:absolute;left:0;top:50%;transform:translateY(-50%);background:linear-gradient(135deg,#ff6b9d,#ff4581);color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.88rem}.btn-got-it{width:100%;padding:1rem 2rem;font-size:1.2rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px #667eea66;margin-top:.5rem}.btn-got-it:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea99;background:linear-gradient(135deg,#5568d3,#6a3d8a)}.btn-start-game{width:100%;padding:1.2rem 2.4rem;font-size:1.44rem;font-weight:700;background:linear-gradient(135deg,#ff6b9d,#ff4581);color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .3s;box-shadow:0 6.4px 24px #ff6b9d99;animation:pulseGlowPink 1.5s ease-in-out infinite;display:flex;align-items:center;justify-content:center;gap:.6rem}@keyframes pulseGlowPink{0%,to{box-shadow:0 6.4px 24px #ff6b9d99}50%{box-shadow:0 9.6px 32px #ff6b9de6}}.btn-start-game:hover{transform:translateY(-2.4px);box-shadow:0 9.6px 32px #ff6b9dcc}.btn-start-game .play-icon{font-size:1.6rem;animation:playIconPulse 1.5s ease-in-out infinite}@media (max-width: 768px){.intro-content{padding:2rem 1.6rem}.intro-header-section{flex-direction:column-reverse;gap:1.2rem;text-align:center}.intro-text{text-align:center}.intro-content h1{font-size:2rem;text-align:center}.intro-description{font-size:.88rem;text-align:center}.intro-mascot{width:144px}.intro-instructions{padding:1.2rem}.intro-instructions h2{font-size:.96rem}.intro-instructions li{font-size:.8rem;padding-left:2rem}.intro-instructions li:before{width:24px;height:24px;font-size:.8rem}.btn-start-game{padding:1rem 1.6rem;font-size:1.2rem}.btn-start-game .play-icon{font-size:1.28rem}}
