.image-selection-view{width:100%;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:40px 20px;overflow-y:auto}.title{text-align:center;color:#fff;font-size:32px;font-weight:700;margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.subtitle{text-align:center;color:#fff;font-size:18px;margin-bottom:40px;opacity:.9}.about-link-wrapper{display:flex;justify-content:center;margin-top:-24px;margin-bottom:24px}.about-link{background:transparent;border:none;color:#ffffffd9;text-decoration:underline;font-size:12px;cursor:pointer}.about-link:hover{color:#fff;text-decoration-color:#ffffffe6}.section{margin-bottom:50px}.section-title{text-align:center;color:#fff;font-size:24px;font-weight:700;margin-bottom:30px;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.image-grid{display:flex;justify-content:center;gap:30px;flex-wrap:wrap;max-width:1200px;margin:0 auto}.image-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 8px 24px #0003;cursor:pointer;transition:all .3s ease;width:280px;position:relative}.image-card:hover{transform:translateY(-8px);box-shadow:0 12px 32px #0000004d}.image-wrapper{position:relative;width:100%;height:200px;border-radius:12px;overflow:hidden;margin-bottom:12px}.image-preview{width:100%;height:100%;object-fit:cover;border-radius:12px}.today-badge{position:absolute;top:8px;right:8px;background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;font-size:12px;font-weight:700;padding:6px 12px;border-radius:20px;box-shadow:0 2px 8px #0000004d;z-index:10;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fffc;display:flex;justify-content:center;align-items:center;border-radius:12px;z-index:5}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.image-name{text-align:center;font-size:18px;font-weight:600;color:#333}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;border-radius:20px;padding:40px;max-width:500px;width:90%;box-shadow:0 16px 48px #0000004d}.about-text{font-size:14px;color:#444;line-height:1.8;margin-bottom:24px}.modal-title{font-size:24px;font-weight:700;color:#333;text-align:center;margin-bottom:30px}.difficulty-options{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.difficulty-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;padding:24px;cursor:pointer;transition:all .3s ease;text-align:center}.difficulty-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #667eea66}.difficulty-name{font-size:22px;font-weight:700;margin-bottom:8px}.difficulty-info{font-size:16px;opacity:.95;margin-bottom:4px}.difficulty-desc{font-size:14px;opacity:.85}.cancel-button{width:100%;background:#e0e0e0;color:#333;border:none;border-radius:12px;padding:16px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.cancel-button:hover{background:#d0d0d0}.play-view{width:100%;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;overflow:hidden}.play-header{display:flex;align-items:center;justify-content:space-between;padding:20px 30px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.play-header-right{display:flex;align-items:center;gap:20px}.back-button{background:#fff;color:#667eea;border:none;border-radius:12px;padding:12px 24px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0000001a}.back-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #00000026}.play-title{color:#fff;font-size:24px;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.preview-button{background:#fffffff2;color:#667eea;border:none;border-radius:12px;padding:12px 24px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0000001a}.preview-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #00000026;background:#fff}@media (max-width: 600px){.play-header{padding:12px 14px;gap:10px;flex-wrap:wrap}.play-title{font-size:18px}.play-header-right{gap:10px}.back-button,.preview-button{padding:10px 14px;font-size:14px;border-radius:10px}.play-info{font-size:12px;padding:6px 10px;border-radius:10px}.play-container{gap:16px;padding:12px}.hand-zone{border-radius:12px;padding:12px}.hand-pieces-container{min-height:100px}.confirm-content{padding:28px 24px;max-width:360px}.confirm-title{font-size:18px}.confirm-message{font-size:14px}.confirm-button{padding:12px 20px;font-size:14px;border-radius:10px}.preview-content{padding:20px}.preview-title{font-size:18px}.preview-close-bottom-button{padding:12px 28px;font-size:14px}}@media (max-width: 380px){.back-button,.preview-button{padding:8px 10px;font-size:13px}.play-info{font-size:11px;padding:4px 8px}}.play-info{color:#fff;font-size:16px;font-weight:600;background:#fff3;padding:8px 16px;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.play-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;padding:20px;overflow-y:auto}.play-zone{background:#fff;border-radius:16px;box-shadow:0 8px 24px #0000004d;position:relative;border:3px solid rgba(255,255,255,.5);overflow:hidden;touch-action:none;aspect-ratio:1 / 1}.puzzle-guide{border:2px dashed rgba(100,100,100,.5);background:#dcdcdccc;box-sizing:border-box;z-index:1}.hand-zone{width:100%;max-width:1200px;background:#fffffff2;border-radius:16px;padding:16px 20px;box-shadow:0 4px 16px #0003;position:relative;overflow-x:auto;overflow-y:hidden}.hand-zone::-webkit-scrollbar{height:8px}.hand-zone::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.hand-zone::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.hand-zone::-webkit-scrollbar-thumb:hover{background:#555}.hand-zone-title{font-size:18px;font-weight:700;color:#333;margin-bottom:4px}.hand-pieces-container{position:relative;width:100%;height:100%;min-height:120px}.puzzle-piece{border:none;transition:all .2s ease;-webkit-user-select:none;user-select:none;box-sizing:border-box;touch-action:none}.puzzle-piece.correct{box-shadow:0 0 12px #4caf5099,inset 0 0 0 2px #4caf504d;filter:brightness(1.05)}.puzzle-piece.hint-shake{animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}.puzzle-piece.snap-success{animation:snapSuccess .5s ease-out}@keyframes snapSuccess{0%{transform:scale(1);box-shadow:0 0 12px #4caf5099,inset 0 0 0 2px #4caf504d}50%{transform:scale(1.08);box-shadow:0 0 20px #4caf50e6,inset 0 0 0 2px #4caf5080;filter:brightness(1.15)}to{transform:scale(1);box-shadow:0 0 12px #4caf5099,inset 0 0 0 2px #4caf504d;filter:brightness(1.05)}}.puzzle-piece.hand-piece{box-shadow:0 4px 8px #0003,0 0 0 2px #0000001a}.puzzle-piece.dragging-piece{box-shadow:0 8px 24px #667eea80,0 0 0 3px #667eea4d;filter:brightness(1.1)}.puzzle-piece:hover{transform:scale(1.05);z-index:10}.completion-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:transparent;display:flex;justify-content:center;align-items:flex-end;z-index:2000;padding:16px;pointer-events:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.completion-content{background:#fff;border-radius:16px;padding:16px 20px;text-align:center;box-shadow:0 10px 28px #00000040;width:min(520px,90vw);animation:slideUp .25s ease;pointer-events:auto}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes scaleIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.completion-icon{font-size:40px;margin-bottom:12px;margin-top:4px;animation:none}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.completion-title{font-size:20px;font-weight:700;color:#333;margin-bottom:8px}.completion-message{font-size:14px;color:#666;margin-bottom:16px}.completion-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;padding:10px 22px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #667eea66}.completion-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea80}@media (max-width: 600px){.completion-content{width:94vw;padding:14px 16px;border-radius:12px}.completion-title{font-size:18px}.completion-message{font-size:13px;margin-bottom:14px}.completion-button{padding:8px 18px;font-size:13px}}.confirm-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:2000;animation:fadeIn .3s ease}.confirm-content{background:#fff;border-radius:20px;padding:40px 50px;max-width:400px;width:90%;box-shadow:0 16px 48px #0000004d;animation:scaleIn .3s ease;text-align:center}.confirm-title{font-size:22px;font-weight:700;color:#333;margin-bottom:12px}.confirm-message{font-size:16px;color:#666;margin-bottom:30px}.confirm-buttons{display:flex;gap:16px;justify-content:center}.confirm-button{border:none;border-radius:12px;padding:14px 36px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:100px}.confirm-cancel{background:#e0e0e0;color:#333}.confirm-cancel:hover{background:#d0d0d0;transform:translateY(-2px)}.confirm-ok{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea66}.confirm-ok:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea80}.preview-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;justify-content:center;align-items:center;z-index:2000;animation:fadeIn .3s ease}.preview-content{background:#fff;border-radius:20px;padding:30px;max-width:90%;max-height:90vh;box-shadow:0 16px 48px #0000004d;animation:scaleIn .3s ease;display:flex;flex-direction:column;align-items:center}.preview-header{display:flex;justify-content:space-between;align-items:center;width:100%;margin-bottom:20px}.preview-title{font-size:24px;font-weight:700;color:#333;margin:0}.preview-close-button{background:#e0e0e0;color:#333;border:none;border-radius:50%;width:36px;height:36px;font-size:20px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.preview-close-button:hover{background:#d0d0d0;transform:scale(1.1)}.preview-image-container{margin-bottom:20px;border-radius:12px;overflow:hidden;box-shadow:0 4px 16px #0003;border:3px solid rgba(255,255,255,.5);background:#fff}.preview-image{display:block;margin:0}.preview-close-bottom-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;padding:14px 40px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #667eea66}.preview-close-bottom-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea80}*{margin:0;padding:0;box-sizing:border-box}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;overflow:hidden}#root{width:100%;height:100vh}
