*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}:root{--primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--secondary-gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--success-gradient: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);--shadow-lg: 0 20px 40px rgba(0, 0, 0, .1);--shadow-md: 0 10px 25px rgba(0, 0, 0, .1);--shadow-sm: 0 5px 15px rgba(0, 0, 0, .08);--border-radius: 16px;--animation-duration: .3s}*{box-sizing:border-box}body{margin:0;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif}.app{max-width:900px;margin:0 auto;padding:2rem;min-height:100vh;display:flex;flex-direction:column;gap:2rem}.header{text-align:center;color:#fff;margin-bottom:1rem;animation:fadeInDown .8s ease-out}.header-icon{font-size:4rem;margin-bottom:1rem;animation:bounce 2s infinite}.header h1{font-size:3rem;margin:.5rem 0;font-weight:700;text-shadow:0 4px 8px rgba(0,0,0,.3);background:linear-gradient(45deg,#fff,#f0f0f0);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.subtitle{font-size:1.2rem;margin:0;opacity:.9;font-weight:300;text-shadow:0 2px 4px rgba(0,0,0,.2)}.upload-section{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:3px dashed #ddd;border-radius:var(--border-radius);padding:3rem 2rem;cursor:pointer;transition:all var(--animation-duration) ease;box-shadow:var(--shadow-md);position:relative;overflow:hidden;animation:fadeInUp .8s ease-out .2s both}.upload-section:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.upload-section:hover:before{left:100%}.upload-section:hover{border-color:#667eea;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.upload-section.drag-over{border-color:#667eea;background:#667eea1a;transform:scale(1.02)}.upload-section.has-file{border-color:#28a745;background:#28a7450d}.file-input-hidden{display:none}.upload-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.upload-placeholder{text-align:center}.upload-icon{font-size:3rem;margin-bottom:1rem;animation:float 3s ease-in-out infinite}.upload-text{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.upload-text strong{font-size:1.3rem;color:#333}.upload-text span{color:#666;font-size:1rem}.upload-formats{color:#888;font-size:.9rem}.file-selected{display:flex;align-items:center;gap:1rem;padding:1rem;background:#28a7451a;border-radius:12px;border:2px solid rgba(40,167,69,.2)}.file-icon{font-size:2rem}.file-info{flex:1;text-align:left}.file-name{font-weight:600;color:#333;margin-bottom:.25rem}.file-size{color:#666;font-size:.9rem}.change-file{color:#667eea;font-size:.9rem;text-decoration:underline}.controls{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:var(--border-radius);box-shadow:var(--shadow-md);animation:fadeInUp .8s ease-out .4s both}.frame-selector h3{margin:0 0 1.5rem;color:#333;font-size:1.3rem;text-align:center}.radio-group{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;margin-bottom:2rem}.radio-option{position:relative;cursor:pointer;padding:1.5rem;border:2px solid #e0e0e0;border-radius:12px;transition:all var(--animation-duration) ease;background:#fff;display:flex;align-items:center;gap:1rem}.radio-option:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:var(--shadow-sm)}.radio-option.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea1a,#764ba21a);box-shadow:var(--shadow-sm)}.radio-option input[type=radio]{display:none}.radio-custom{width:20px;height:20px;border:2px solid #ddd;border-radius:50%;position:relative;transition:all var(--animation-duration) ease}.radio-option.selected .radio-custom{border-color:#667eea;background:#667eea}.radio-option.selected .radio-custom:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background:#fff;border-radius:50%}.radio-content{display:flex;align-items:center;gap:.75rem}.radio-icon{font-size:1.5rem}.radio-label{font-weight:500;color:#333}.extract-button,.download-button{display:inline-flex;align-items:center;gap:.75rem;padding:1rem 2rem;font-size:1.1rem;font-weight:600;color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all var(--animation-duration) ease;position:relative;overflow:hidden;min-width:200px;justify-content:center}.extract-button{background:var(--primary-gradient);box-shadow:var(--shadow-sm)}.extract-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.extract-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.extract-button.processing{background:#6c757d}.download-button{background:var(--success-gradient);box-shadow:var(--shadow-sm)}.download-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.button-icon{font-size:1.2rem}.button-text{position:relative}.loading-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s linear infinite}.result-section{animation:fadeInUp .8s ease-out .6s both}.result-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:var(--border-radius);box-shadow:var(--shadow-lg);text-align:center}.result-card h3{margin:0 0 1.5rem;color:#333;font-size:1.4rem}.image-container{position:relative;margin-bottom:1.5rem;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-md)}.extracted-image{width:100%;max-height:500px;object-fit:contain;display:block;transition:transform var(--animation-duration) ease}.image-container:hover .extracted-image{transform:scale(1.02)}.action-buttons{display:flex;flex-direction:column;gap:1.5rem;align-items:center}.ai-services{display:flex;flex-direction:column;align-items:center;gap:.75rem}.ai-services-label{font-size:.9rem;color:#666;font-weight:500}.ai-links{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.ai-link{display:flex;align-items:center;gap:.4rem;padding:.5rem .75rem;background:#667eea1a;border:1px solid rgba(102,126,234,.2);border-radius:8px;text-decoration:none;color:#667eea;font-size:.85rem;font-weight:500;transition:all var(--animation-duration) ease}.ai-link:hover{background:#667eea26;border-color:#667eea4d;transform:translateY(-1px);box-shadow:0 2px 8px #667eea33}.ai-icon{font-size:1rem}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes spin{to{transform:rotate(360deg)}}.custom-controls{background:#667eea0d;border:2px solid rgba(102,126,234,.2);border-radius:12px;padding:1.5rem;margin-top:1rem;animation:fadeInUp .3s ease-out}.input-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.input-group:last-of-type{margin-bottom:.5rem}.input-group label{font-weight:500;color:#333;font-size:.95rem}.frame-input,.seconds-input{padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all var(--animation-duration) ease;background:#fff}.frame-input:focus,.seconds-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.framerate-info{font-size:.85rem;color:#666;text-align:center;padding:.5rem;background:#fffc;border-radius:6px;margin-top:.5rem}@media (max-width: 1024px){.app{max-width:95%;padding:1.5rem}.header h1{font-size:2.5rem}.radio-group{grid-template-columns:1fr 1fr}}@media (max-width: 768px){.app{padding:1rem;gap:1.5rem}.header h1{font-size:2.2rem}.subtitle{font-size:1rem}.upload-section{padding:2rem 1rem}.upload-icon{font-size:2.5rem}.upload-text strong{font-size:1.1rem}.radio-group{grid-template-columns:1fr;gap:1rem}.custom-controls{padding:1rem}.input-group{margin-bottom:.75rem}.radio-option{padding:1rem}.radio-content{justify-content:center;text-align:center}.extract-button,.download-button{padding:.875rem 1.5rem;font-size:1rem;min-width:180px}.ai-links{gap:.5rem}.ai-link{font-size:.8rem;padding:.4rem .6rem}.file-selected{flex-direction:column;text-align:center;gap:.75rem}.controls,.result-card{padding:1.5rem}}@media (max-width: 640px){.app{padding:.75rem;gap:1.25rem}.header h1{font-size:2rem}.header-icon{font-size:3.5rem}.upload-section{padding:1.5rem 1rem}.radio-option{padding:.875rem;flex-direction:column;text-align:center;gap:.5rem}.radio-custom{align-self:center}.radio-content{flex-direction:column;gap:.5rem}.extract-button,.download-button{width:100%;padding:1rem;min-width:unset}.action-buttons{gap:1rem}.ai-services-label{font-size:.85rem}}@media (max-width: 480px){.app{padding:.5rem;gap:1rem}.header h1{font-size:1.8rem}.header-icon{font-size:3rem}.subtitle{font-size:.9rem}.upload-section{padding:1.25rem .75rem}.upload-icon{font-size:2rem}.upload-text strong{font-size:1rem}.upload-text span{font-size:.9rem}.upload-formats{font-size:.8rem}.controls,.result-card{padding:1.25rem}.frame-selector h3{font-size:1.1rem}.radio-option{padding:.75rem}.radio-icon{font-size:1.25rem}.radio-label{font-size:.9rem}.button-icon{font-size:1rem}.extract-button,.download-button{padding:.875rem;font-size:.95rem}.result-card h3{font-size:1.2rem}.extracted-image{max-height:300px}}@media (max-width: 360px){.app{padding:.25rem}.header h1{font-size:1.6rem}.header-icon{font-size:2.5rem}.upload-section{padding:1rem .5rem}.controls,.result-card{padding:1rem}.radio-group{gap:.75rem}.radio-option{padding:.625rem}.extract-button,.download-button{padding:.75rem;font-size:.9rem}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.extracted-image{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}@media (max-width: 768px) and (orientation: landscape){.header{margin-bottom:.5rem}.header h1{font-size:1.8rem}.header-icon{font-size:2.5rem;margin-bottom:.5rem}.subtitle{font-size:.9rem}.app{gap:1rem}.upload-section{padding:1.5rem 1rem}.controls,.result-card{padding:1.25rem}.extracted-image{max-height:250px}}@media print{.app{background:#fff!important;color:#000!important}.header,.upload-section,.controls{display:none!important}.result-section{animation:none!important}.result-card{background:#fff!important;box-shadow:none!important;border:1px solid #ccc!important}}
