*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px;color:#333}.container{max-width:800px;margin:0 auto;background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);overflow:hidden}header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:40px 30px;text-align:center}header h1{font-size:2.5em;margin-bottom:10px}header p{font-size:1.1em;opacity:.9}main{padding:30px}.tabs{display:flex;gap:10px;margin-bottom:20px;border-bottom:2px solid #eee;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:12px 24px;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1em;color:#666;transition:all .3s;white-space:nowrap;flex-shrink:0}.tab.active,.tab:hover{color:#667eea}.tab.active{border-bottom-color:#667eea;font-weight:600}.tab-content{display:none}.tab-content.active{display:block}.mode-description{background:#f8f9ff;padding:15px;border-radius:8px;margin-bottom:20px;color:#555;font-size:.9em}.camera-section{margin-bottom:30px;background:#000;border-radius:8px;overflow:hidden;position:relative;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center}.camera-section video{width:100%;height:100%;object-fit:cover}.upload-section{margin-bottom:30px}.upload-label{display:block;width:100%;padding:40px;border:3px dashed #667eea;border-radius:12px;text-align:center;cursor:pointer;transition:all .3s ease;background:#f8f9ff}.upload-label:hover{background:#f0f2ff;border-color:#764ba2}.upload-label:active{transform:scale(.98)}.prompt-section{margin-bottom:20px}.prompt-section label{display:block;margin-bottom:10px;font-weight:600;color:#555}.prompt-input{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:1em;font-family:inherit;resize:vertical;transition:border-color .3s}.prompt-input:focus{outline:none;border-color:#667eea}.controls{display:flex;gap:10px;margin-bottom:30px}.btn{flex:1 1;padding:14px 24px;border:none;border-radius:8px;font-size:1em;font-weight:600;cursor:pointer;transition:all .3s}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,.4)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#f0f0f0;color:#666}.btn-secondary:hover{background:#e0e0e0}.loading{text-align:center;padding:40px}.spinner{border:4px solid #f3f3f3;border-top-color:#667eea;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.result{margin-top:30px;padding:20px;background:#f8f9ff;border-radius:12px;border-left:4px solid #667eea}.result h3{margin-bottom:15px;color:#667eea}.result-content{line-height:1.6;color:#555;white-space:pre-wrap;font-size:1.5em;font-weight:700;text-align:center;padding:20px;border-radius:8px}.result-content.found{background:#d4edda;color:#155724;border:2px solid #c3e6cb}.result-content.not-found{background:#f8d7da;color:#721c24;border:2px solid #f5c6cb}.error{margin-top:20px;padding:15px;background:#fee;border:2px solid #fcc;border-radius:8px;color:#c33}.hidden{display:none}.examples-container{display:flex;flex-direction:column;gap:30px}.example-item{background:#f9f9f9;padding:20px;border-radius:8px;border:1px solid #e0e0e0}.example-item h3{margin-bottom:15px;color:#333;font-size:1.3em}.example-view-controls{display:flex;gap:10px;margin-bottom:15px}.view-btn{padding:8px 16px;background:#e0e0e0;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:all .3s;font-weight:500}.view-btn:hover{background:#d0d0d0}.view-btn.active{background:#667eea;color:#fff}.example-canvas-container{background:#000;padding:20px;border-radius:4px;margin-bottom:15px;text-align:center;overflow:hidden}.example-canvas{max-width:100%;height:auto;display:block;margin:0 auto;border:1px solid #333}@media (max-width:600px){header h1{font-size:2em}header{padding:30px 20px}main{padding:20px}.controls{flex-direction:column}.tab{padding:10px 16px;font-size:.9em}.tabs{gap:5px}}