@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@300;400;500;600;700;800&family=Fira+Code:wght@400;500&display=swap";:root{--bg-main:#0a0c10;--bg-card:#12151b;--bg-card-hover:#181d26;--bg-input:#1b202a;--border-color:#ffffff0f;--border-color-focus:#3b82f666;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--accent-blue:#3b82f6;--accent-blue-glow:#3b82f633;--accent-green:#10b981;--accent-green-glow:#10b98133;--accent-orange:#f97316;--accent-orange-glow:#f9731633;--accent-red:#ef4444;--accent-red-glow:#ef444433;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-title:"Outfit", sans-serif;--font-mono:"Fira Code", monospace;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-full:9999px;--transition-fast:.15s ease;--transition-normal:.25s cubic-bezier(.4, 0, .2, 1);--shadow-lg:0 10px 25px -5px #0000004d, 0 8px 10px -6px #0000004d}*{box-sizing:border-box;scrollbar-width:thin;scrollbar-color:var(--bg-input) transparent;margin:0;padding:0}body{background-color:var(--bg-main);color:var(--text-primary);font-family:var(--font-sans);width:100vw;height:100dvh;overflow:hidden}input,button,select,textarea{color:inherit;font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--bg-input);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-container{grid-template-rows:auto 1fr;width:100vw;height:100dvh;display:grid}.navbar{background-color:var(--bg-card);border-bottom:1px solid var(--border-color);z-index:10;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.brand-container{align-items:center;gap:10px;display:flex}.brand-logo{color:var(--accent-blue);font-size:20px;font-family:var(--font-title);letter-spacing:-.5px;background:linear-gradient(135deg,#3b82f6,#10b981);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-weight:800}.nav-actions{align-items:center;gap:15px;display:flex}.ws-status-badge{border-radius:var(--radius-full);border:1px solid var(--border-color);background-color:#ffffff08;align-items:center;gap:6px;padding:4px 10px;font-size:12px;display:flex}.ws-status-dot{border-radius:var(--radius-full);width:8px;height:8px}.ws-status-dot.connected{background-color:var(--accent-green);box-shadow:0 0 8px var(--accent-green)}.ws-status-dot.disconnected{background-color:var(--accent-red);box-shadow:0 0 8px var(--accent-red)}.ws-status-dot.connecting{background-color:var(--accent-orange);box-shadow:0 0 8px var(--accent-orange);animation:1.5s infinite alternate pulse}@keyframes pulse{0%{opacity:.4}to{opacity:1}}.main-content{height:calc(100vh - 56px);display:flex;overflow:hidden}.sidebar{border-right:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:320px;height:100%;transition:width var(--transition-normal), opacity var(--transition-normal), border var(--transition-normal);background-color:#12151b99;flex-shrink:0;grid-template-rows:auto auto 1fr auto;display:grid;overflow:hidden}.main-content.sidebar-collapsed .sidebar{opacity:0;pointer-events:none;border-right:0 solid #0000;width:0}.search-container{border-bottom:1px solid var(--border-color);padding:12px}.search-input-wrapper{position:relative}.search-input{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;transition:var(--transition-fast);outline:none;padding:8px 12px;font-size:13px}.search-input:focus{border-color:var(--accent-blue);box-shadow:0 0 8px var(--accent-blue-glow)}.filter-controls{border-bottom:1px solid var(--border-color);background-color:#ffffff03;grid-template-columns:1fr auto;align-items:center;gap:8px;padding:8px 12px;display:grid}.filter-select{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;outline:none;padding:6px 10px;font-size:12px}.filter-select:focus{border-color:var(--accent-blue)}.sort-btn{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.sort-btn:hover{background-color:var(--bg-card-hover)}.coins-scroll-list{flex-direction:column;gap:6px;padding:8px;display:flex;overflow-y:auto}.coin-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);text-align:left;align-items:center;gap:10px;padding:8px;display:flex}.coin-card:hover{background-color:var(--bg-card-hover);border-color:#ffffff1f}.coin-card.selected{border-color:var(--accent-blue);background-color:#3b82f614}.coin-image-container{perspective:1000px;flex-shrink:0;width:50px;height:50px}.coin-image-flipper{width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,0,.2,1);position:relative}.coin-card:hover .coin-image-flipper{transform:rotateY(180deg)}.coin-face{backface-visibility:hidden;border-radius:var(--radius-full);background-color:#000;border:1.5px solid #ffffff1a;width:100%;height:100%;position:absolute;overflow:hidden}.coin-face img{object-fit:cover;width:100%;height:100%}.coin-face.back{transform:rotateY(180deg)}.coin-info{flex-direction:column;flex-grow:1;min-width:0;display:flex}.coin-name{white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:13px;font-weight:600;overflow:hidden}.coin-specs{color:var(--text-secondary);flex-wrap:wrap;gap:6px;font-size:10px;display:flex}.coin-spec-item{border-radius:var(--radius-sm);background-color:#ffffff0a;padding:1px 4px}.viewport{background-color:var(--bg-main);flex-grow:1;grid-template-rows:auto 1fr;width:100%;height:100%;display:grid;overflow:hidden}.viewport-header{background-color:var(--bg-card);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.viewport-coin-title{align-items:center;gap:12px;display:flex}.selected-coin-title-name{font-family:var(--font-title);font-size:18px;font-weight:700}.coin-specs-row{color:var(--text-secondary);gap:8px;font-size:12px;display:flex}.viewport-actions-row{align-items:center;gap:16px;display:flex}.measurement-selector-wrapper{align-items:center;gap:10px;display:flex}.selector-label{color:var(--text-secondary);font-size:12px}.btn{border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:500;display:inline-flex}.btn-primary{background-color:var(--accent-blue);color:#fff}.btn-primary:hover{box-shadow:0 0 10px var(--accent-blue-glow);background-color:#2563eb}.btn-secondary{border-color:var(--border-color);color:var(--text-primary);background-color:#ffffff0d}.btn-secondary:hover{background-color:#ffffff14}.btn-danger{background-color:var(--accent-red);color:#fff}.btn-danger:hover{box-shadow:0 0 10px var(--accent-red-glow);background-color:#dc2626}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none!important}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background-color:#040508d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--bg-card);border-radius:var(--radius-lg);width:90%;max-width:460px;box-shadow:var(--shadow-lg);border:1px solid #ffffff17;animation:.25s cubic-bezier(.16,1,.3,1) modalEnter;overflow:hidden}@keyframes modalEnter{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-title{font-family:var(--font-title);font-size:18px;font-weight:700}.modal-close-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;font-size:20px;display:flex}.modal-close-btn:hover{color:var(--text-primary)}.modal-body{padding:20px}.modal-footer{border-top:1px solid var(--border-color);background-color:#ffffff03;justify-content:flex-end;gap:10px;padding:14px 20px;display:flex}.form-group{margin-bottom:16px}.form-group label{color:var(--text-secondary);margin-bottom:6px;font-size:12px;font-weight:500;display:block}.form-control{background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;transition:var(--transition-fast);outline:none;padding:8px 12px;font-size:13px}.form-control:focus{border-color:var(--accent-blue);box-shadow:0 0 8px var(--accent-blue-glow)}.form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.file-upload-zone{border:2px dashed var(--border-color);border-radius:var(--radius-md);text-align:center;cursor:pointer;transition:var(--transition-fast);background-color:#ffffff03;padding:15px}.file-upload-zone:hover{border-color:var(--accent-blue);background-color:#3b82f605}.file-upload-preview{border-radius:var(--radius-sm);object-fit:contain;border:1px solid var(--border-color);background-color:#000;width:100%;height:80px;margin-top:8px}.viewport-content{padding:24px;overflow-y:auto}.empty-view{height:100%;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:40px;display:flex}.empty-view-icon{background:linear-gradient(135deg, var(--text-muted), #ffffff1a);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:16px;font-size:48px}.measurement-dashboard{grid-template-columns:1fr;gap:20px;height:100%;display:grid}.controller-grid{grid-template-columns:1fr 340px;align-items:start;gap:24px;display:grid}.arena-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);flex-direction:column;gap:15px;padding:16px;display:flex}.arena-canvas-wrapper{justify-content:center;width:100%;display:flex;position:relative}.arena-canvas{border-radius:var(--radius-md);cursor:crosshair;background-color:#0c0d12;border:2px solid #ffffff1a;max-width:100%}.dial-controls-row{justify-content:space-around;gap:20px;margin-top:10px;display:flex}.dial-card{text-align:center;flex-direction:column;align-items:center;gap:8px;display:flex}.dial-title{color:var(--text-secondary);font-size:11px;font-weight:600}.dial-canvas{border-radius:var(--radius-md);cursor:grab;background-color:#0c0d12;border:2.5px solid #ffffff1a}.dial-canvas:active{cursor:grabbing}.measurement-details-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px}.measurement-details-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:flex-end;margin-bottom:20px;padding-bottom:12px;display:flex}.measurement-title-block{text-align:left;flex-direction:column;gap:2px;display:flex}.measurement-title-text{font-family:var(--font-title);margin:0;font-size:17px;font-weight:700}.measurement-id-text{color:var(--text-muted);font-size:11px;font-family:var(--font-mono)}.measurement-time-text{color:var(--text-secondary);font-size:12px}.details-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px;margin-bottom:24px;display:grid}.detail-item{border-radius:var(--radius-md);background-color:#ffffff05;border:1px solid #ffffff0a;padding:10px}.detail-label{color:var(--text-muted);text-transform:uppercase;margin-bottom:4px;font-size:11px}.detail-value{font-family:var(--font-title);font-size:16px;font-weight:600}.data-view-section{border-top:1px solid var(--border-color);padding-top:20px}.data-view-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.data-title{font-family:var(--font-title);font-size:16px;font-weight:700}.json-pre{border:1px solid var(--border-color);border-radius:var(--radius-md);max-height:300px;font-family:var(--font-mono);color:var(--accent-green);text-align:left;background-color:#06070a;padding:16px;font-size:12px;overflow:auto}.controller-params-panel{flex-direction:column;gap:20px;display:flex}.params-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px}.params-card-title{font-family:var(--font-title);border-bottom:1px solid var(--border-color);margin-bottom:15px;padding-bottom:8px;font-size:15px;font-weight:700}.actions-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px}.actions-grid{grid-template-columns:1fr;gap:10px;display:grid}.console-logs-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);flex-direction:column;gap:12px;padding:16px;display:flex}.console-header{justify-content:space-between;align-items:center;display:flex}.console-title{font-family:var(--font-title);font-size:14px;font-weight:700}.console-clear-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:11px}.console-clear-btn:hover{color:var(--text-primary)}.console-output{border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-mono);text-align:left;background-color:#06070a;flex-direction:column;gap:4px;height:150px;padding:10px;font-size:11px;display:flex;overflow-y:auto}.log-entry{word-break:break-all;line-height:1.4}.log-entry.in{color:#38bdf8}.log-entry.out{color:#f472b6}.log-entry.system{color:var(--text-muted)}.log-entry.success{color:var(--accent-green)}.log-entry.error{color:var(--accent-red)}.coin-card-img-side{border-radius:var(--radius-full);object-fit:cover;background-color:#000;border:1.5px solid #ffffff1a;width:50px;height:50px}.coin-placeholder-face{color:#718096;border-radius:var(--radius-full);background:radial-gradient(circle,#2d323b 0%,#12151b 100%);border:1.5px solid #ffffff14;justify-content:center;align-items:center;width:100%;height:100%;font-size:18px;display:flex}.camera-modal-content{max-width:520px}.camera-stream-container{aspect-ratio:1;border-radius:var(--radius-md);background-color:#000;border:1px solid #ffffff26;width:100%;max-width:400px;position:relative;overflow:hidden;box-shadow:inset 0 0 20px #000c}.camera-video{object-fit:cover;width:100%;height:100%;display:block;position:absolute;top:0;left:0}.camera-scanner-overlay{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.scanner-circle{aspect-ratio:1;border:2px dashed #ffffffa6;border-radius:50%;flex-shrink:0;width:70%;height:70%;animation:2s ease-in-out infinite pulse-border;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 9999px #04050899}.scanner-circle.locked{border-style:solid;border-color:#10b981;animation:none}.scanner-tip{color:#fff;letter-spacing:.5px;text-shadow:0 1px 2px #000c;z-index:10;white-space:nowrap;background-color:#000000b3;border:1px solid #ffffff1a;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:500;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}@keyframes pulse-border{0%{border-color:#ffffff80}50%{border-color:#10b981f2}to{border-color:#ffffff80}}.btn-shutter{padding-left:20px;padding-right:20px;font-weight:600;color:#fff!important;background-image:linear-gradient(135deg,#10b981 0%,#059669 100%)!important;border:none!important}.btn-shutter:hover{background-image:linear-gradient(135deg,#34d399 0%,#10b981 100%)!important}.error-banner{color:#fca5a5;border-radius:var(--radius-sm);background-color:#ef444426;border:1px solid #ef44444d;padding:8px 12px;font-size:13px}@media (width<=768px){body{width:100%;height:100dvh;overflow:hidden}.app-container{grid-template-rows:auto 1fr;width:100%;height:100dvh;overflow:hidden}.navbar{flex-wrap:wrap;gap:10px;height:auto;padding:10px 14px}.nav-actions{justify-content:space-between;gap:10px;width:100%}.main-content{height:100%;display:block;position:relative;overflow:hidden}.sidebar{z-index:100;background-color:var(--bg-card);border-right:1px solid var(--border-color);opacity:1;height:100%;transition:transform var(--transition-normal), opacity var(--transition-normal);position:absolute;top:0;bottom:0;left:0;transform:translate(0);box-shadow:10px 0 30px #00000080;width:290px!important}.main-content.sidebar-collapsed .sidebar{opacity:0;pointer-events:none;transform:translate(-100%)}.coins-scroll-list{height:100%;overflow-y:auto}.viewport{width:100%;height:100%;display:block;overflow-y:auto}.viewport-header{flex-direction:column;gap:14px;padding:16px 12px;align-items:stretch!important}.viewport-coin-title{flex-direction:column;align-items:flex-start;gap:6px}.coin-specs-row{flex-wrap:wrap;gap:6px;font-size:11px}.viewport-actions-row{flex-direction:column;align-items:stretch;gap:10px;width:100%}.viewport-actions-row .btn{width:100%}.measurement-selector-wrapper{flex-direction:column;align-items:stretch;gap:6px;width:100%;display:flex}.measurement-selector-wrapper select{width:100%!important}.measurement-details-header{flex-direction:column;align-items:flex-start;gap:8px}.measurement-time-text{color:var(--text-muted);font-size:11px}.viewport-content{height:auto;padding:12px;overflow-y:visible}.controller-grid{grid-template-columns:1fr;gap:16px}.modal-content{flex-direction:column;width:95%;max-height:90vh;display:flex}.modal-body{flex-grow:1;padding:16px;overflow-y:auto}.modal-footer,.modal-header{padding:12px 16px}.camera-modal-content{max-width:95%;height:auto;max-height:95vh}}@media (width<=480px){.details-grid{grid-template-columns:1fr 1fr;gap:10px}.form-grid{grid-template-columns:1fr}.dial-controls-row{flex-wrap:wrap;justify-content:center;gap:16px}.dial-card{width:100%;max-width:180px}}.sidebar-toggle-btn{border:1px solid var(--border-color);color:var(--text-primary);transition:all var(--transition-fast);background-color:#ffffff0d}.sidebar-toggle-btn:hover{background-color:var(--bg-card-hover);border-color:#ffffff26}.launch-disabled-banner{text-align:center;background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:12px;margin-top:10px;padding:40px 20px;display:flex}.launch-disabled-banner h3{color:var(--text-primary);font-family:var(--font-title);font-size:17px;font-weight:700}.launch-disabled-banner p{max-width:340px;font-size:13px;line-height:1.5}.sidebar-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:90;background-color:#040508a6;animation:.25s ease-out fadeInOverlay;position:absolute;inset:0}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.sidebar-right{border-left:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:320px;height:100%;transition:width var(--transition-normal), opacity var(--transition-normal), border var(--transition-normal);background-color:#12151b99;flex-shrink:0;grid-template-rows:auto 1fr;display:grid;overflow:hidden}.main-content.right-sidebar-collapsed .sidebar-right{opacity:0;pointer-events:none;border-left:0 solid #0000;width:0}.sidebar-right-header{border-bottom:1px solid var(--border-color);font-family:var(--font-title);justify-content:space-between;align-items:center;padding:16px;font-size:15px;font-weight:700;display:flex}.measurements-scroll-list{flex-direction:column;gap:6px;padding:8px;display:flex;overflow-y:auto}.measurement-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);text-align:left;flex-direction:column;gap:4px;padding:10px 12px;display:flex}.measurement-card:hover{background-color:var(--bg-card-hover);border-color:#ffffff26}.measurement-card.selected{border-color:var(--accent-blue);background-color:#3b82f614}.measurement-card-header{justify-content:space-between;align-items:center;display:flex}.measurement-card-title{color:var(--text-primary);font-size:13px;font-weight:600}.measurement-card-time{color:var(--text-muted);font-size:11px}.measurement-card-details{color:var(--text-secondary);justify-content:space-between;font-size:11px;display:flex}.measurement-card-angle{color:var(--accent-orange);font-weight:500}@media (width>=769px){.measurement-selector-wrapper{display:none!important}}@media (width<=768px){.sidebar-right{z-index:100;background-color:var(--bg-card);border-left:1px solid var(--border-color);opacity:1;height:100%;transition:transform var(--transition-normal), opacity var(--transition-normal);position:absolute;top:0;bottom:0;right:0;transform:translate(0);box-shadow:-10px 0 30px #00000080;width:290px!important}.main-content.right-sidebar-collapsed .sidebar-right{opacity:0;pointer-events:none;transform:translate(100%)}}.btn-icon-download{color:var(--accent-orange);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;padding:6px;transition:all .2s ease-in-out;display:inline-flex}.btn-icon-download:hover{color:#fb923c;background-color:#f973161f;transform:scale(1.1);box-shadow:0 0 8px #f9731633}.detail-item-sm{border-radius:var(--radius-md);text-align:left;background-color:#ffffff05;border:1px solid #ffffff0a;flex-direction:column;gap:2px;padding:8px 12px;display:flex}.detail-label-sm{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:600}.detail-value-sm{font-family:var(--font-title);color:var(--text-primary);font-size:14px;font-weight:700}
