:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;background-color:#f8faff;color:#1f1f1f}body{margin:0;min-width:320px;min-height:100vh}#app{width:100%;margin:0 auto}.site-header{background-color:#1a73e8;padding:1rem 2rem;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center}.site-header h1{margin:0;font-size:1.8em;color:#fff}.site-header nav{display:flex;gap:1rem}.nav-link{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:background-color .3s}.nav-link:hover{background-color:#ffffff1a}.main-content{padding:2rem;max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.camera-section{display:flex;gap:2rem;justify-content:center}.camera-container{flex:1;max-width:480px;position:relative;aspect-ratio:4/3;overflow:hidden;border-radius:8px;box-shadow:0 4px 6px #1a73e81a;border:2px solid #1a73e8}.preview-container{flex:1;max-width:480px;background:#fff;border-radius:8px;box-shadow:0 4px 6px #1a73e81a;overflow:hidden;display:flex;align-items:center;justify-content:center;aspect-ratio:4/3}#video{width:100%;height:100%;object-fit:cover}#canvas{display:none}.preview-image{width:100%;height:100%;object-fit:contain;display:block}.capture-controls{text-align:center;padding:1rem 0}.results-section{width:100%}.result{padding:1.5rem;border-radius:8px;background-color:#fff;box-shadow:0 2px 4px #1a73e81a;border:1px solid rgba(26,115,232,.2)}button{background-color:#1a73e8;color:#fff;border:none;padding:.8em 1.6em;font-size:1em;border-radius:8px;cursor:pointer;transition:background-color .3s}button:hover{background-color:#1557b0}button:disabled{background-color:#c2d3f3;cursor:not-allowed}.feedback-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e5e7eb}.feedback-buttons{display:flex;gap:1rem;justify-content:center;margin-top:.5rem}.feedback-btn{padding:.5rem 2rem;border-radius:4px;font-weight:500}.feedback-btn.correct{background-color:#1e8e3e}.feedback-btn.correct:hover{background-color:#167c2e}.feedback-btn.incorrect{background-color:#d93025}.feedback-btn.incorrect:hover{background-color:#c41e1a}.loading{display:flex;justify-content:center;align-items:center;min-height:100px;color:#1a73e8}.error{color:#d93025;padding:1rem;border-radius:4px;background-color:#fde8e8}.feedback-success{margin-top:1rem;padding:.75rem;background-color:#e6f4ea;color:#1e8e3e;border-radius:4px;font-weight:500}.about-container{max-width:800px;margin:0 auto;padding:2rem}.about-container h2{color:#1a73e8;margin-bottom:2rem}.about-container section{margin-bottom:2rem}.about-container h3{color:#1557b0;margin-bottom:1rem}@media (max-width: 768px){.main-content{padding:1rem;gap:1rem}.camera-section{flex-direction:column;gap:1rem}.camera-container,.preview-container{max-width:100%}.capture-controls{padding:.5rem 0}.site-header{padding:1rem;flex-direction:column;gap:.5rem;text-align:center}}.contact-form{max-width:500px;margin:2rem auto}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#1f1f1f;font-weight:500}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid #e5e7eb;border-radius:4px;font-size:1rem;transition:border-color .3s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#1a73e8;box-shadow:0 0 0 2px #1a73e833}.submit-btn{width:100%;background-color:#1a73e8;color:#fff;padding:.75rem;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background-color .3s}.submit-btn:hover{background-color:#1557b0}.submit-btn:disabled{background-color:#c2d3f3;cursor:not-allowed}.success-message{color:#1e8e3e;text-align:center;padding:1rem;background-color:#e6f4ea;border-radius:4px}.error-message{color:#d93025;text-align:center;padding:1rem;background-color:#fde8e8;border-radius:4px;margin-bottom:1rem}.consent-form{margin:1rem 0}.consent-email{width:100%;padding:.5rem;margin-bottom:.5rem;border:1px solid #e5e7eb;border-radius:4px;background-color:#fff;color:#1f1f1f}.error-message{color:#d93025;font-size:.875rem;margin-top:.25rem}.consent-checkbox{margin-top:1rem;display:flex;align-items:flex-start;gap:.5rem;background-color:#fff;color:#1f1f1f}.consent-checkbox input[type=checkbox]{margin-top:.25rem}iframe{width:100%;height:640px}.detection-overlay{position:absolute;top:0;left:0;pointer-events:none;z-index:10}.camera-container{position:relative}.loading.api-call{display:flex;flex-direction:column;align-items:center;gap:1rem}.loading-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #1a73e8;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.detection-summary{background:linear-gradient(135deg,#e6f4ea,#f8fff8);border:1px solid #1e8e3e;border-radius:8px;padding:1rem;margin:1rem 0}.detection-summary ul{margin:.5rem 0;padding-left:1.5rem}.detection-summary li{margin:.5rem 0;color:#1e8e3e;font-weight:500}@media (max-width: 768px){.detection-overlay{max-width:100%;height:auto}}
