.camera-view{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px #0000001a}.camera-header{padding:1rem 1.5rem;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.camera-header h2{color:#2c3e50;font-size:1.2rem;margin:0}.camera-controls{display:flex;gap:.5rem}.btn{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .3s ease;font-weight:500}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-start{background:#27ae60;color:#fff}.btn-start:hover:not(:disabled){background:#229954}.btn-stop{background:#e74c3c;color:#fff}.btn-stop:hover:not(:disabled){background:#c0392b}.btn-analyze{background:#3498db;color:#fff}.btn-analyze:hover:not(:disabled){background:#2980b9}.camera-container{position:relative;background:#1a1a1a;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center}.camera-container video{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .3s ease}.camera-container video.active{opacity:1}.camera-loading{position:absolute;text-align:center;color:#fff}.spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.camera-error{position:absolute;text-align:center;color:#fff;padding:2rem}.camera-error p{margin-bottom:1rem;font-size:1.1rem}.camera-error .btn{background:#3498db;color:#fff}.streaming-indicator{position:absolute;top:1rem;right:1rem;background:#ef4444e6;color:#fff;padding:.3rem .8rem;border-radius:20px;display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600}.rec-dot{width:8px;height:8px;background:#fff;border-radius:50%;animation:blink 1.5s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.engagement-chart{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000001a;margin-bottom:1.5rem}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.chart-header h3{color:#2c3e50;font-size:1.2rem;margin:0}.chart-info{display:flex;gap:1rem;align-items:center}.data-points{background:#e8f4fd;color:#2980b9;padding:.3rem .8rem;border-radius:20px;font-size:.85rem;font-weight:500}.time-range{color:#7f8c8d;font-size:.85rem}.chart-container{height:350px;position:relative;margin-bottom:1rem}.no-data{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#95a5a6}.no-data p{font-size:1.2rem;margin:0 0 .5rem}.no-data span{font-size:.9rem}.chart-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.stat-item{display:flex;flex-direction:column;gap:.3rem}.stat-label{color:#7f8c8d;font-size:.85rem;font-weight:500}.stat-value{color:#2c3e50;font-size:1.3rem;font-weight:700}@media (max-width: 768px){.chart-container{height:250px}.chart-header{flex-direction:column;align-items:flex-start;gap:.5rem}.chart-info{width:100%;justify-content:space-between}}.dashboard{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000001a}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.dashboard-header h2{color:#2c3e50;font-size:1.2rem;margin:0}.session-badge{background:#e8f4fd;color:#2980b9;padding:.3rem .8rem;border-radius:20px;font-size:.85rem;font-weight:500}.engagement-meter{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;padding:1.5rem;color:#fff;margin-bottom:1.5rem}.engagement-meter h3{margin:0 0 1rem;font-size:1rem;opacity:.9}.meter-container{text-align:center}.meter-value{font-size:3rem;font-weight:700;margin-bottom:.5rem}.meter-label{font-size:1.1rem;margin-bottom:1rem;opacity:.9}.meter-bar{background:#fff3;border-radius:20px;height:10px;overflow:hidden}.meter-fill{height:100%;border-radius:20px;transition:width .5s ease}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;margin-bottom:1rem}.stat-card{background:#f8f9fa;border-radius:10px;padding:1rem;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.stat-icon{font-size:2rem;margin-bottom:.5rem}.stat-value{font-size:1.8rem;font-weight:700;color:#2c3e50;margin-bottom:.3rem}.stat-label{font-size:.85rem;color:#7f8c8d;font-weight:500}.update-time{text-align:center;color:#95a5a6;font-size:.85rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e0e0e0}.alert-panel{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px #0000001a}.alert-header{padding:1rem 1.5rem;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.alert-header h2{color:#2c3e50;font-size:1.2rem;margin:0}.btn-clear{padding:.4rem .8rem;background:#e74c3c;color:#fff;border:none;border-radius:6px;font-size:.85rem;cursor:pointer;transition:background .3s ease}.btn-clear:hover{background:#c0392b}.alerts-container{max-height:300px;overflow-y:auto}.no-alerts{padding:3rem 1.5rem;text-align:center;color:#95a5a6}.no-alerts p{font-size:1.1rem;margin-bottom:.5rem}.no-alerts span{font-size:.9rem}.alerts-list{padding:.5rem}.alert-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;margin-bottom:.5rem;border-radius:8px;border-left:4px solid;background:#f8f9fa;transition:transform .2s ease}.alert-item:hover{transform:translate(2px)}.alert-error{border-color:#e74c3c;background:#fee}.alert-warning{border-color:#f39c12;background:#fff5e6}.alert-info{border-color:#3498db;background:#e8f4fd}.alert-default{border-color:#95a5a6}.alert-icon{font-size:1.2rem;flex-shrink:0}.alert-content{flex:1}.alert-message{color:#2c3e50;margin:0 0 .3rem;font-size:.95rem}.alert-time{color:#7f8c8d;font-size:.8rem}.analysis-results{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px #0000001a}.results-header{padding:1rem 1.5rem;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.results-header h2{color:#2c3e50;font-size:1.2rem;margin:0}.timestamp{color:#7f8c8d;font-size:.85rem}.results-content{padding:1.5rem}.engagement-score-section{margin-bottom:1.5rem}.engagement-score-section h3{color:#2c3e50;font-size:1rem;margin-bottom:1rem}.score-display{text-align:center}.score-value{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:1rem}.score-bar{background:#e0e0e0;border-radius:20px;height:12px;overflow:hidden}.score-fill{height:100%;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;transition:width .5s ease}.alerts-section,.recommendations-section,.ai-insights{margin-bottom:1.5rem}.alerts-section h3,.recommendations-section h3,.ai-insights h3{color:#2c3e50;font-size:1rem;margin-bottom:.8rem}.alerts-section ul,.recommendations-section ul{list-style:none;padding:0}.alerts-section li,.recommendations-section li{padding:.5rem 1rem;margin-bottom:.5rem;border-radius:6px;font-size:.95rem}.alerts-section li{background:#fee;color:#c0392b;border-left:3px solid #e74c3c}.recommendations-section li{background:#e8f4fd;color:#2980b9;border-left:3px solid #3498db}.insight-item{margin-bottom:1rem}.insight-item strong{color:#2c3e50;display:block;margin-bottom:.5rem}.insight-item p{color:#555;line-height:1.5;margin:0}.behaviors-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1rem}.behavior-item{background:#f8f9fa;padding:.8rem;border-radius:6px;display:flex;justify-content:space-between;align-items:center}.behavior-label{color:#7f8c8d;font-size:.85rem;text-transform:capitalize}.behavior-value{color:#2c3e50;font-weight:600;font-size:1.1rem}.app{min-height:100vh;display:flex;flex-direction:column;background:#f5f7fa}.app-header{background:#fff;padding:1rem 2rem;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center}.app-header h1{color:#2c3e50;font-size:1.8rem}.connection-status{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#666}.status-indicator{width:10px;height:10px;border-radius:50%;background:#e74c3c}.status-indicator.connected{background:#27ae60;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.app-main{flex:1;display:flex;gap:2rem;padding:2rem;max-width:1600px;margin:0 auto;width:100%}.left-panel,.right-panel{flex:1;display:flex;flex-direction:column;gap:1.5rem}.app-footer{background:#fff;padding:1rem 2rem;text-align:center;border-top:1px solid #e0e0e0;color:#666;font-size:.9rem}@media (max-width: 1024px){.app-main{flex-direction:column}}*{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;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh;display:flex;flex-direction:column}
